table maximum value column

3 Ansichten (letzte 30 Tage)
Luca cadalo
Luca cadalo am 18 Jun. 2017
Bearbeitet: Andrei Bobrov am 19 Jun. 2017
Hi, I have this table
0 0
0 0
0,0100000000000000 0
0,0100000000000000 1
0,0100000000000000 2
0,0200000000000000 0
0,0200000000000000 1
0,0200000000000000 2
but the table that I want is this one
0 0
0.01 2
0.02 2
the second column is the highest value of each number (0 0.01 0.02)
if someone can help me I would really appreciate because I am a little bit stuck in this problem I do not know even how to start to solve it
Thanks in advance for your time
Luca

Akzeptierte Antwort

Andrei Bobrov
Andrei Bobrov am 18 Jun. 2017
Bearbeitet: Andrei Bobrov am 18 Jun. 2017
A=[0 0
0 0
0.0100000000000000 0
0.0100000000000000 1
0.0100000000000000 2
0.0200000000000000 0
0.0200000000000000 1
0.0200000000000000 2];
[g,ii] = findgroups(A(:,1));
out = [ii,splitapply(@max,A(:,2),g)];
or
[ii,~,g] = unique(A(:,1));
out = [ii,accumarray(g,A(:,2),[],@max)];
  3 Kommentare
Andrei Bobrov
Andrei Bobrov am 19 Jun. 2017
Please attach your tables as mat-file.
Andrei Bobrov
Andrei Bobrov am 19 Jun. 2017
Bearbeitet: Andrei Bobrov am 19 Jun. 2017
A=[0 0
0 0
0.0100000000000000 0
0.0100000000000000 1
0.0100000000000000 2
0.0200000000000000 0
0.0200000000000000 1
0.0200000000000000 2];
A= num2cell(A,1);
T = table(A{:},'va',{'x','y'});
%solution
T_out = varfun(@max,T,'group','x');

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Tables 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!

Translated by