Find 這個函數用處也挺大的,這幾天看很多程序都見到這一函數,今天要好好給闡述,了解下這個函數是為了找到矩陣或者是數組,向量中的非零元素。下面一大段英文沒耐心看。看看例子就行了。
第一個用法是
ndices = find(X)
X = [1 0 4 -3 0 0 0 8 6];
indices = find(X)
返回x中非零元素的序號從1開始
indices =
1 3 4 8 9
若x是個矩陣呢?
x= [1 0 ;1 5 ;4 0 ]
find(x)得到的是
1
2
3
5
是一列矢量,非零元素的序號是按一列一列的算
第二個用法
index= find(X, k)
index = find(X, k, 'first')
index= find(X, k, 'last')
這三個是找前K個非零元素,前兩式功能一致,第三式指從最后一個元素算起(但返回的元素索引順序還是正序)。
重點說一下
第三個用法
[row,col] = find(X, ...)
[row,col,v] = find(X, ...)
例如
X = [3 2 0;
-5 0 7;
0 0 1];
[r,c,v] = find(X>2)
r =
1
2
c =
1
3
v =
2×1 logical array
1
1
這樣看看不出什么?看下式就比較明了。
r c v
1 1 1
2 3 1
就是說矩陣中第1行第1列和第2行第3列的元素滿足X>2為真用1來表示。余下的類似。
r代表row, c代表colum, v代表value ,注意v的值是邏輯值。
下面繼續:
X = [3 2 0;
-5 0 7;
0 0 1];
[r,c,v]= find(X)
這個得到的v是X中第幾行第幾列的非零元素,注意這個區別
r =
1
2
1
2
3
c =
1
1
2
3
3
v =
3
-5
2
7
1
以上內容來源於:https://blog.csdn.net/h2008066215019910120/article/details/11820363
