find maximum value for each year in a 2 columns array

I have an array with two columns, column one year (1975-2020) and column two discharge values. I need to find the maximum discharge amount for each year and have them saved in another matrix.
Can you please help me with this?
input:
1975 200
1975 85
.
.
.
2002 110
2002 95
2002 32
...
2020 120
...
desired output
1975 200
...
2002 110
...
2020 120

 Respuesta aceptada

Tommy
Tommy el 16 de Abr. de 2020
Try this:
[G, y] = findgroups(input(:,1));
output = [y splitapply(@max, input(:,2), G)];

5 comentarios

Thanks but it gives me this error:
Error using splitapply (line 99)
The data variables must have the same number of rows as the vector of group numbers. The group number
vector has 46 row(s), and data variable 1 has 934768 row(s).
Tommy
Tommy el 16 de Abr. de 2020
Do you mind posting the code you ran which gave you this error?
[years,groups] = findgroups(year_Q(:,1));
>> output = [years splitapply(@max, year_Q(:,2), groups)];
Tommy
Tommy el 16 de Abr. de 2020
Editada: Tommy el 16 de Abr. de 2020
Switch the outputs.
[groups, years] = findgroups(year_Q(:,1));
>> output = [years splitapply(@max, year_Q(:,2), groups)];
nevermind! sorted it out
Thanks

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Etiquetas

Preguntada:

el 16 de Abr. de 2020

Comentada:

el 16 de Abr. de 2020

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by