Добрый день. Помогите плиз поправить алгоритм. Написано на яве, но думаю это не критично
Дан массив double[] l, нужно вывести индексы элементов от наименьшего к наибольшему.
Есть такой код
Код:
int idx[] = new int[l.length];
for (int i = 0;i<idx.length;i++)
{
idx[i]=i;
}
int temp;
for (int i=0; i<n; i++)
{
for (int j=i+1; j<n; j++)
{
if (l[idx[i]] > l[idx[j]])
{
temp = idx[i];
idx[i] = idx[j];
idx[j] = temp;
}
}
}
но он является неустойчивым, т.е. для массива {100,10,10,1}
он выведет 3210 а, не 3120