How do I return rows of a matrix based on the value of the maximum element.
1 次查看(过去 30 天)
显示 更早的评论
Can someone help me? I am using MATLAB R2011b and I am having problems returning rows based on the maximum value in (:, 2:end). I have two .txt files with data in the format:
A =
1901 1.0 0.9 1.4 3.0 3.9 8.3 9.5 9.4 8.8 6.6 4.1 1.7
1902 0.3 2.4 1.5 3.7 5.1 8.3 10.4 10.3 7.6 5.9 2.7 0.7
1903 0.6 0.1 0.7 2.6 4.4 7.6 9.3 10.1 7.9 4.7 -0.7 1.2
B =
1901 5.9 7.0 8.2 10.5 14.3 17.1 17.6 18.6 16.5 13.2 10.2 6.6
1902 5.4 8.6 8.2 13.5 13.8 17.9 18.8 19.3 16.8 12.9 8.9 6.1
1903 5.3 6.1 7.7 11.0 14.3 18.0 17.5 18.1 16.6 11.9 5.8 6.5
If I use:
D = [A(:,1), (B(:,2:13)-A(:,2:13))] and get:
1901 4.9 6.1 6.8 7.5 10.4 8.8 8.1 9.2 7.7 6.6 6.1 4.9
1902 5.1 6.2 6.7 9.8 8.7 9.6 8.4 9.0 9.2 7.0 6.2 5.4
1903 4.7 6.0 7.0 8.4 9.9 10.4 8.2 8.0 8.7 7.2 6.5 5.3
I expect to get:
1903 4.9 6.1 6.8 7.5 10.4 8.8 8.1 9.2 7.7 6.6 6.1 4.9
1905 4.7 6.0 7.0 8.4 9.9 10.4 8.2 8.0 8.7 7.2 6.5 5.3
13 个评论
DGM
2021-4-25
It returns both rows associated with 10.4, which is the global maximum of the data difference.
"I can see 2 values in D which are the same and they are the maximums."
Which is what you were saying.
回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Resizing and Reshaping Matrices 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!