find the multiple max values
Ältere Kommentare anzeigen
I have a matrix
8 23 44 19
44 5 62 1
7 6 12 33
6 55 24 8
and I want to find 3 largest values(reserve duplicate matches),and then make the other be 0
just like
0 0 44 0
44 0 62 0
0 0 0 0
0 55 0 0
I have read some book ,but I still have no idea
help me plz
3 Kommentare
Aditya Verma
am 16 Jun. 2020
Hello, could you please specify what you have tried until now, and in which part you are facing problem.
chung yen chang
am 18 Jun. 2020
chung yen chang
am 18 Jun. 2020
Akzeptierte Antwort
Weitere Antworten (1)
Stephen23
am 16 Jun. 2020
Where M is your matrix:
>> U = unique(M(:));
>> X = ismember(M,U(end-2:end));
>> M(~X) = 0
M =
0 0 44 0
44 0 62 0
0 0 0 0
0 55 0 0
3 Kommentare
chung yen chang
am 18 Jun. 2020
"Thanks, bro this answer can work very well"
Note my answer actually gives the output that you asked for (unlike the answer that you accepted):
>> M = [4,4,4;4,4,4;3,2,1]
M =
4 4 4
4 4 4
3 2 1
>> U = unique(M(:));
>> X = ismember(M,U(end-2:end));
>> M(~X) = 0
M =
4 4 4
4 4 4
3 2 0
madhan ravi
am 18 Jun. 2020
However maxk(...) gives the right answer xD, but i do agree the loophole.
Kategorien
Mehr zu Descriptive Statistics finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!