Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
coolplayer
2 / 2 / 0
Регистрация: 30.05.2011
Сообщений: 33
25.01.2012, 20:48     Поиск k-ого наименьшего элемента #1
Друзья есть код на паскале, нужно переписать на с++. Это алгоритм поиска к-го наименьшего элемента. У меня получается криво, с ошибками.

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;
                  }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.01.2012, 20:48     Поиск k-ого наименьшего элемента
Посмотрите здесь:

C++ определить номер наименьшего по абсолютной величине элемента массива
C++ Поиск индекса самого наименьшего элемента в массиве
C++ вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск заданного элемента
C++ Поиск наименьшего элемента массива
C++ Поиск наименьшего расстояния от одного элемента массиа до остальных
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 21:20     Поиск k-ого наименьшего элемента #2
coolplayer, достаточно отсортировать и взять элемент #k.
coolplayer
2 / 2 / 0
Регистрация: 30.05.2011
Сообщений: 33
25.01.2012, 21:25  [ТС]     Поиск k-ого наименьшего элемента #3
Цитата Сообщение от soon Посмотреть сообщение
coolplayer, достаточно отсортировать и взять элемент #k.
у меня порядок роста сложности должен быть не более n
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 21:53     Поиск k-ого наименьшего элемента #4
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, как вы понимаете, в любом случае один раз прокрутится.
coolplayer
2 / 2 / 0
Регистрация: 30.05.2011
Сообщений: 33
25.01.2012, 21:58  [ТС]     Поиск k-ого наименьшего элемента #5
Вот поправили слегка.

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;
}
Но особо не понятно, что алгоритм возвращает.
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
25.01.2012, 22:34     Поиск k-ого наименьшего элемента #6
Цитата Сообщение от coolplayer Посмотреть сообщение
Вот поправили слегка.
Неа. С циклами все равно косяки, будет выход за границы массива.
Yandex
Объявления
25.01.2012, 22:34     Поиск k-ого наименьшего элемента
Ответ Создать тему
Опции темы

Текущее время: 19:17. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru