Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
2 / 2 / 1
Регистрация: 30.05.2011
Сообщений: 33

Поиск k-ого наименьшего элемента

25.01.2012, 20:48. Показов 2574. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Друзья есть код на паскале, нужно переписать на с++. Это алгоритм поиска к-го наименьшего элемента. У меня получается криво, с ошибками.

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
procedure Find(k: integer);
var
L,R,i,j: integer;
w,x: integer;
begin
  L:=1; R:=N;
  while L<R-1 do
  begin
    x:=a[k];
    i:=L;
    j:=R;
    REPEAT
      while a[i]<x do
        i:=i+1;
      while x<a[j] do
        j:=j-1;
      if i<=j then
      begin
        w:=a[i];
        a[i]:=a[j];
        a[j]:=w;
        i:=i+1;
        j:=j-1;
      end;
    UNTIL i>j;
    if j<k then
      L:=i;
    if k<i then
      R:=j;
  end;
end;
Мое:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
    int N=10;
    int a[N];
    int k=4;
   
    
int L,R,i,j;
int w,x,i1;
 
 for(i1=1;i1<N;i1++)
 {
                  cin>>a[i1];
                  }
 
 
  L=1; R=N;
 while (L<R-1) {
  
    x=a[k];
    i=L;
    j=R;
    do {
       do
        {i=i+1;}
        while(a[i]<x);
      do
        {j=j-1;}
        while(x<a[j]);
      if (i<=j)
      {
        w=a[i];
        a[i]=a[j];
        a[j]=w;
        i=i+1;
        j=j-1;
     }
    } while(i>j);
    if (j<k) L=i;
    if (k<i) R=j;
 
 
 
}  
    
     for(i1=1;i1<N;i1++)
 {
                  cout<<a[i1]<<endl;
                  }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.01.2012, 20:48
Ответы с готовыми решениями:

Поиск наименьшего элемента массива
#include&lt;iostream.h&gt; #include&lt;conio.h&gt; const n=5; char StrBuf; int i; int poshyk(int a, int NextIndex); void vved(int a); ...

Поиск по вектору наименьшего отсутствующего элемента
В общем, есть вектор, в нем хранятся значения типа &lt;unsigned int&gt;. Как за наименьшее количество проходов по вектору найти наименьший...

Поиск индекса самого наименьшего элемента в массиве
Нужно написать шаблонную функцию, которая будет возвращать индекс самого наименьшего элемента в массиве.

5
 Аватар для soon
2554 / 1319 / 178
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 21:20
coolplayer, достаточно отсортировать и взять элемент #k.
0
2 / 2 / 1
Регистрация: 30.05.2011
Сообщений: 33
25.01.2012, 21:25  [ТС]
Цитата Сообщение от soon Посмотреть сообщение
coolplayer, достаточно отсортировать и взять элемент #k.
у меня порядок роста сложности должен быть не более n
0
 Аватар для soon
2554 / 1319 / 178
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 21:53
coolplayer, а вы учли, что в плюсах индексы массивов идут с нуля до N - 1?

А также
C++
1
2
3
4
do
{
    i=i+1;
} while(a[i]<x);
и
Pascal
1
2
while a[i]<x do
    i:=i+1;
не совсем идентичны. do...while, как вы понимаете, в любом случае один раз прокрутится.
0
2 / 2 / 1
Регистрация: 30.05.2011
Сообщений: 33
25.01.2012, 21:58  [ТС]
Вот поправили слегка.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
    
    int N=10;
    int a[N];
    int k=5;
   
   cout<<endl<<k<<endl;
   
    
int L,R,i,j;
int w,x,i1;
 
 for(i1=1;i1<=N;i1++)
 {
                  cin>>a[i1];
                  }
 
 
L=1;R=N;
    while(L<R-1)
    {
    x=a[k];
    i=L;
    j=R;
    do
    {
        while(a[i]<x) i++;
        while(x<a[j]) j--;
        if (i<=j) {
                w=a[i];
                a[i]=a[j];
                a[j]=w;
                i++;j--;
                } 
    }
    while(i>j);
    if (j<k) L=i;
    if (k<j) R=j;
}
Но особо не понятно, что алгоритм возвращает.
0
 Аватар для soon
2554 / 1319 / 178
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 22:34
Цитата Сообщение от coolplayer Посмотреть сообщение
Вот поправили слегка.
Неа. С циклами все равно косяки, будет выход за границы массива.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.01.2012, 22:34
Помогаю со студенческими работами здесь

Фибоначчиев поиск наименьшего индекса заданного элемента (Pascal -> C++)
При выполнении лаб. работы возникли сложности, решила поискать в интернете пример кода, нашла только упрощенную версию, но как-то не...

Поиск наименьшего расстояния от одного элемента массиа до остальных
Дан неотсортированный массив чисел (но это не беда, отсортируем...) тогда получится отсортированный по возрастанию массив чисел)) В нём...

Функция: поиск экстремального (наибольшего или наименьшего) элемента массива
Написать программу с функцией для поиска экстремального числа(наибольшего или наименьшего) элемента массива. Массив заполнить случайными...

Вывести на экран значения 0-ого, 3-ого и 13-ого битов числа n в формате short int
Задано число n в формате short int. Вывести на экран значения 0-ого, 3-ого и 13-ого битов представления в ЭВМ этого числа. Объяснить...

Получить новую матрицу путем вычитания из каждого элемента данной матрицы ее наименьшего элемента
Доброго времени суток!) я был бы благодарен получить небольшую консультацию и правку в моем коде по этой задачке: Дана действительная...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru