Matlab中数组元素引用——三种方法
1.Matlab中数组元素引用有三种方法
1
2
3
|
1 .下标法(subscripts) 2 .索引法(index) 3 .布尔法(Boolean) |
注意:在使用这三种方法之前,大家头脑一定要清晰的记住,Matlab中数组元素是按列存储(与Fortran一样),比如说下面的二维数组
1
2
3
4
|
A= 8 1 6 3 5 7 4 9 2 |
Matlab的存储顺序是8,3,4,1,5,9,6,7,2,也就是说先行后列,对于3维数组呢,就是先行后列再页对应个元素的索引和下标分别为
1
2
3
4
5
6
7
8
9
10
|
Element
Index Subscripts 8 1 ( 1 , 1 ) 3 2 ( 2 , 1 ) 4 3 ( 3 , 1 ) 1 4 ( 1 , 2 ) 5 5 ( 2 , 2 ) 9 6 ( 3 , 2 ) 6 7 ( 1 , 3 ) 7 8 ( 2 , 3 ) 2 9 ( 3 , 3 ) |
从上面的例子中已经很清晰的说明了下标和索引的区别了,也就是说Matlab为每个元素分配了一个唯一识别的ID(即index)
2.下标法引用
A(ii,jj):其中ii和jj可以是一维向量、标量、“:”号或者“end”
大家对下标估计比较熟悉,由于在C语言中接触过,但是我这里需要强调的是,Matlab的下标是可以多行多列同时引用的,而像C语言等一次只能引用一个,比如
1
2
3
4
|
A( 2 : 3 , 3 :- 1 : 1 )表示引用数组中的 2 ~ 3 行, 3 ~ 1 列对应的元素 A(:,end)表示引用最后一列元素,“:”表示所有列或行,“end”表示最后一列或列,“end-n”表示倒数第n行或列 A( 1 ,end- 1 )表示引用第 1 行倒数第 2 个元素 A([ 2 1 3 3 ],[ 1 1 2 2 1 ])表示引用按两个向量引用指定的元素,即A中的第 2 , 1 , 3 , 3 行和第 1 , 1 , 2 , 2 , 1 列对应的元素 |
举几个例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
>>A=magic( 3 ) A
= 8 1 6 3 5 7 4 9 2 >>A( 2 : 3 , 3 :- 1 : 1 ) ans
= 7 5 3 2 9 4 >>A(:,end) ans
= 6 7 2 >>A( 1 ,end- 1 ) ans
= 1 >>A([ 2 1 3 3 ],[ 1 1 2 2 1 ]) ans
= 3 3 5 5 3 8 8 1 1 8 4 4 9 9 4 4 4 9 9 4 |
2.索引法引用(说白了索引就是存储顺序)
A(index):index可以是任意的数组,index的元素必须是正整数,且不大于numel(A),返回的是一个尺寸与index一样的数组
下标和索引之间可以通过ind2sub和sub2ind函数相互转换,具体可以看帮助,很简单
[I,J] = ind2sub(siz,IND)
IND = sub2ind(siz,I,J)
还有使用A(:)就可以将数组A转换为列向量
A(8):表示引用A的第8个元素
B=A([1 10 5 2 2 1 3]):表示依次引用A的第1,10,5,2,2,1,3个元素,返回与index尺寸相同的数组,也就是说size(B)=size(index)
A([2 5 9;1 1 1;8 5 6]):返回的时侯是一个3*3的矩阵
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
>>A=magic( 5 )%括号中为索引值 A
= 17 ( 1 ) 24 ( 6 ) 1 ( 11 ) 8 ( 16 ) 15 ( 21 ) 23 ( 2 ) 5 ( 7 ) 7 ( 12 ) 14 ( 17 ) 16 ( 22 ) 4 ( 3 ) 6 ( 8 ) 13 ( 13 ) 20 ( 18 ) 22 ( 23 ) 10 ( 4 ) 12 ( 9 ) 19 ( 14 ) 21 ( 19 ) 3 ( 24 ) 11 ( 5 ) 18 ( 10 ) 25 ( 15 ) 2 ( 20 ) 9 ( 25 ) >>A( 8 ) ans
= 6 >>A([ 1 10 5 2 2 1 3 ]) ans
= 17 18 11 23 23 17 4 >>A([ 2 5 9 ; 1 1 1 ; 8 5 6 ]) ans
= 23 11 12 17 17 17 6 11 24 |
3.布尔法引用
A(X):X是一个有0和1组成布尔型数据,且size(A)=size(X),对应位置为1则留下该数据,0则去掉,最后按A中的存储顺序,返回一个列向量
假如说A是3*3的数组
A(logical([1 0 0;0 1 0;0 0 1])):表示引用了数组A的对角线元素,注意必须使用logical将0/1数组转换为布尔型
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
>>A=magic( 3 )%生成一个 3 * 3 的数组 A= 8 1 6 3 5 7 4 9 2 >>x=logical([ 1 1 0 ; 0 1 1 ; 1 0 1 ])%将 double 转化为 boolean 型数据 x
= 1 1 0 0 1 1 1 0 1 >>A(x)%引用对应位置为 1 的数据,返回列向量 ans
= 8 4 1 5 7 2 >>x=A> 5 %是有了比较语句,返回布尔型数据,对应位置数据大于 5 的为 1 ,否则为 0 x
= 1 0 1 0 0 1 0 1 0 >>A(x)%返回大于A中大于 5 的元素,其实该命令可以一次性执行A(A> 5 )或者find(A> 5 ),前者返回具体元素,后者返回大于 5 的数据的索引值 ans
= 8 9 6 7 >>A(A> 5 )%一次性执行上面的命令 ans
= 8 9 6 7 >>indx=find(A> 5 )%查找A中对于 5 的元素,返回它们的索引(index)值,此时我们可以通过A(index)返回具体的元素 index
= 1 6 7 8 |