三種方法。
1、下標法(subscripts)
A(ii,jj):其中ii和jj可以是一維向量、標量、“:”號或者“end”
比如:
A(2:3,3:-1:1)表示引用數組中的2~3行,3~1列對應的元素
A(:,end)表示引用最后一列元素,“:”表示所有列或行,“end”表示最后一列或列,“end-n”表示倒數第n行或列
A(1,end-1)表示引用第1行倒數第2個(gè)元素
A([2 1 3 3],[1 1 2 2 1])表示引用按兩個(gè)向量引用指定的元素,即A中的第2,1,3,3行和第1,1,2,2,1列對應的元素
2、索引法(index)
A(index):index可以是任意的數組,index的元素必須是正整數,且不大于numel(A),返回的是一個(gè)尺寸與index一樣的數組,下標和索引之間可以通過(guò)ind2sub和sub2ind函數相互轉換。
3、布爾法(Boolean)
A(X):X是一個(gè)有0和1組成布爾型數據,且size(A)=size(X),對應位置為1則留下該數據,0則去掉,最后按A中的存儲順序,返回一個(gè)列向量。
假如說(shuō)A是3*3的數組,A(logical([1 0 0;0 1 0;0 0 1])):表示引用了數組A的對角線(xiàn)元素,注意必須使用logical將0/1數組轉換為布爾型。
擴展資料:
注意事項
Matlab中數組元素是按列存儲(與Fortran一樣),比如說(shuō)下面的二維數組
A=
8 1 6
3 5 7
4 9 2
Matlab的存儲順序是8,3,4,1,5,9,6,7,2,也就是說(shuō)先行后列,對于3維數組呢,就是先行后列再頁(yè)對應個(gè)元素的索引和下標分別為:
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)
從上面的例子中已經(jīng)很清晰的說(shuō)明了下標和索引的區別了,也就是說(shuō)Matlab為每個(gè)元素分配了一個(gè)唯一識別的ID(即index)。
你好!!!
舉例:首先我們要知道數組的是按線(xiàn)性的順序存放在一起的,比如a[0][2]和a[1][0]是連在一起的,后面的依次類(lèi)推、、、
int a[2][3]{1,2,3,4,5,6};
int *p=*a;表示把數組的的第一行第一個(gè)元素的地址給指針變量,但是*p=a是錯誤的!!!
輸入數組的元素可以使用數組本身:a[i][j],代表第i行,第j列的元素的值;
其實(shí)系統認為二維數組名就是二維指針,我們可以把數組名當做指針使用:
*(*(a+i)+j)表示代表第i行,第j列的元素的值。
要是使用剛才的指針*(p+n),注意此時(shí)的n是從0---5,可以輸出數組中的任何一個(gè)元素,你也許會(huì )問(wèn):數組時(shí)二維的,而指針變量p是一維的,為什么可以輸出所有元素呢???剛才不是說(shuō)了嗎??:首先我們要知道數組的是按線(xiàn)性的順序存放在一起的,比如a[0][2]和a[1][0]是連在一起的,后面的依次類(lèi)推、、、
一般情況下:都是使用a[i][j],和*(*(a+i)+j)的形式、、、當然還有很多方法,要是都列出來(lái),恐怕要幾張紙呢??
你只要把書(shū)本好好看看,多想想,自己就有一些認識了。
要是有什么不理解的問(wèn)題,我們可以交流一下!!
假設聲明一個(gè)int類(lèi)型的數組:
int[] a=new int[]{1,2,3};
int a[]=new int[]{1,2,3};//兩種沒(méi)什么區別,只是上面可讀性比較好
數組的lenght屬性獲取的是一個(gè)int類(lèi)型的數字,他表示的是數組的長(cháng)度,比如a.lenght得到的值為3;
數組是通過(guò)元素下標來(lái)獲取值的,而數組的元素下標是從0開(kāi)始的,方式為a[0]得到的值就是1,a[1]得到的值就是2.。。。
for循環(huán)顯示數組中的元素方法:
for(i=0;i<a.length;i++){ System.out.println("第"+(i+1)+"個(gè)數:"+a[i]); }
我不太明白什么叫半個(gè)指針的引用,但:
1.數據可以引用
2.可以通過(guò)引用數組名改變任何元素
template//用N我們可以傳遞任何大小的數組
void change( int (&intarr)[N] ) // intarr就是數組引用,數組的大小為N個(gè)元素
{
intarr[0] = 10 ; //通過(guò)引用改變元素
}
int main()
{
int arr[20] = { 0 } ;
change( arr ) ; //ok N = 20 ;
int arr2[30] = { 0 } ;
change(arr2) ; // N = 30
int (&ref)[30] = arr2 ;
ref[0] = 10 ; //引用改變元素
}
LZ解決問(wèn)題的思路很清晰,怎么說(shuō)自己不靈光呢. 你這樣的方法很適合編程的.
聲明:本網(wǎng)站尊重并保護知識產(chǎn)權,根據《信息網(wǎng)絡(luò )傳播權保護條例》,如果我們轉載的作品侵犯了您的權利,請在一個(gè)月內通知我們,我們會(huì )及時(shí)刪除。
蜀ICP備2020033479號-4 Copyright ? 2016 學(xué)習?shū)B(niǎo). 頁(yè)面生成時(shí)間:3.069秒