Indexing every value from matrix not only unique values
2 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Hello
For example if I have a matrix like:
A =[ 2 , 2 , 4 , 1 ,3 ;
3 , 1 , 10 , 100]
Is there a posibility to find the index of each value? I tried with find function but it is not working for same values and based on my research I found only solutions either for the same values from the matrix or unique. Not a combination.
Thank you!
0 Kommentare
Akzeptierte Antwort
Jan
am 20 Jul. 2021
Of course you can use find():
A = [2, 2, 4, 1, 3; ...
3, 1, 10, 100, 200]; % 200 added to match number of elements per row...
[i1, i2] = find(A == 2)
Now you get the row and column indices of the elements, which are 2.
Do you want to distinguish all elements even if they have the same number? Then this is trivial: Just use the indices.
8 Kommentare
Jan
am 21 Jul. 2021
Faster alternatives:
A = [2, 2, 4, 1, 3; ...
3, 1, 10, 100, 200];
S = size(A);
[i1, i2] = ind2sub(S, 1:numel(A))
% Or:
[S1, S2] = size(A);
Index = [repelem(1:S1, S2); repmat(1:S2, 1, S1)]
Weitere Antworten (0)
Siehe auch
Kategorien
Mehr zu Matrix Indexing finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!