Suppose I have a Javascript array, like so:
var test = ['b', 'c', 'd', 'a'];
I want to sort the array. Obviously, I can just do this to sort the array:
test.sort(); //Now test is ['a', 'b', 'c', 'd']
But what I really want is an array of indices that indicates the position of the sorted elements with respect to the original elements. I'm not quite sure how to phrase this, so maybe that is why I am having trouble figuring out how to do it.
If such a method was called sortIndices(), then what I would want is:
var indices = test.sortIndices();
//At this point, I want indices to be [3, 0, 1, 2].
'a' was at position 3, 'b' was at 0, 'c' was at 1 and 'd' was a 2 in the original array. Hence, [3, 0, 1, 2].
One solution would be to sort a copy of the array, and then cycle through the sorted array and find the position of each element in the original array. But, that feels clunky.
Is there an existing method that does what I want? If not, how would you go about writing a method that does this?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…