keeping track of the original indices of an array after sorting

조회 수: 63 (최근 30일)
I have an array let's say A=[5 4 1 2 3]. Now I have sorted these arrays in ascending order.So the resulting array will now be [1 2 3 4 5]. I use sort(A,'ascend') function to sort this. The question is how can I get the indices of the original array with respect to my new array. originally my indices were 1,2,3,4,5 for corresponding values of 5,4,1,2,3 and now the indices have changed to 3,4,5,2,1. How can I get these indices efficiently in Matlab?
  댓글 수: 1
Stephen23
Stephen23 2015년 6월 25일
편집: Stephen23 2015년 6월 25일
The documentation clearly explains that the function sort has two outputs... the second output are the indices that you are after.

댓글을 달려면 로그인하십시오.

채택된 답변

Mischa Kim
Mischa Kim 2015년 6월 25일
Md, simply use
[B,I] = sort(A,'ascend')
B =
1 2 3 4 5
I =
3 4 5 2 1

추가 답변 (2개)

Andy
Andy 2017년 4월 3일
and B = A(I), according to documentation, isn't it?
I get following:
>> x = [ 1 3 2 7; 4 3 2 1]
x =
1 3 2 7
4 3 2 1
>> [y,i] = sort(x,2)
y =
1 2 3 7
1 2 3 4
i =
1 3 2 4
4 3 2 1
>> y1 = x(i)
y1 =
1 3 4 3
3 3 4 1
I see y1 is different from y ...
  댓글 수: 2
Stephen23
Stephen23 2017년 4월 3일
편집: Stephen23 2018년 3월 21일
"and B = A(I), according to documentation, isn't it?"
The documentation states "if A is a vector, then B = A(I)." Is your input a vector? NO. However you can esaily read the rest of the documentation, where it explains the output for matrices and arrays: "The index vectors are oriented along the same dimension that sort operates on. For example, if A is a 2-by-3 matrix, then [B,I] = sort(A,2) sorts the elements in each row of A. The output I is a collection of 1-by-3 row index vectors describing the rearrangement of each row of A."
And your data shows this clearly:
i =
1 3 2 4
4 3 2 1
Have a look: do you see that these are the indices along each row, which is exactly what the documentation states that you would get. It means you cannot use A(I) syntax. You could use sub2ind though.

댓글을 달려면 로그인하십시오.


Leelakrishna Vuriti
Leelakrishna Vuriti 2019년 12월 3일
Capture2.JPG
how to arrange the values in ascending order along with its corresponding index change ? what is the command for this ? help me out !

카테고리

Help CenterFile Exchange에서 Shifting and Sorting Matrices에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by