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