How can already used elements be eliminated one by one in 2D matrix while moving upwards? | Efficienlty
2 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
JAI PRAKASH
el 2 de Nov. de 2018
Comentada: JAI PRAKASH
el 3 de Nov. de 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 comentarios
Respuesta aceptada
James Tursa
el 3 de Nov. de 2018
Editada: James Tursa
el 3 de Nov. de 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
Más respuestas (1)
Image Analyst
el 3 de Nov. de 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 comentarios
Walter Roberson
el 3 de Nov. de 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;]
Ver también
Categorías
Más información sobre Data Distribution Plots en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!