How can already used elements be eliminated one by one in 2D matrix while moving upwards? | Efficienlty
2 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
JAI PRAKASH
am 2 Nov. 2018
Kommentiert: JAI PRAKASH
am 3 Nov. 2018
Input
input = [1 2 0;
2 3 4;
4 5 6];
Output
Output= [1 0 0;
2 3 0;
4 5 6];
Why efficiently : For inputting a big matrix of say 360000 x 36.
0 Kommentare
Akzeptierte Antwort
James Tursa
am 3 Nov. 2018
Bearbeitet: James Tursa
am 3 Nov. 2018
r = rot90(inputMatrix,-1); % turn rows into columns with last row as first column
[~,ix] = unique(r); % get the unique linear indexing with preference to leftmost columns
result = zeros(size(r)); % initialize result as all 0's
result(ix) = r(ix); % fill in the unique values with preference to leftmost columns
result = rot90(result); % rotate back to original orientation
Weitere Antworten (1)
Image Analyst
am 3 Nov. 2018
Use unique():
inputMatrix = [1 2 0;
2 3 4;
4 5 6]
[~, ia, ic] = unique(inputMatrix);
output = zeros(size(inputMatrix)); % Initialize
output(ia) = inputMatrix(ia)
4 Kommentare
Walter Roberson
am 3 Nov. 2018
That output contradicts the original pattern. For that "should be" output to be true, then the output for
input = [1 2 0;
2 3 4;
4 5 6];
should be
[1 2 0;
3 4 0;
5 6 0;]
Siehe auch
Kategorien
Mehr zu Data Distribution Plots 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!