Показать сообщение отдельно
  #1  
Старый 25.05.2013, 18:48
Exodus Exodus вне форума
Прохожий
 
Регистрация: 25.05.2013
Сообщения: 2
Версия Delphi: java 7
Репутация: 10
По умолчанию Поиск индексов элементов массива от наименьшего к наибольшему

Добрый день. Помогите плиз поправить алгоритм. Написано на яве, но думаю это не критично
Дан массив 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
Ответить с цитированием