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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Irishka_23
Сообщений: n/a
#1

исправите ошибку - C++

17.05.2012, 15:57. Просмотров 269. Ответов 0
Метки нет (Все метки)

вот алгоритм
Программа реализует алгоритм R поразрядной сортировки списков [2]:
R1 [Цикл по k.] Вначале установить P ← LOC(RN ), указатель на последнюю запись. Затем выполнить шаги с R2 по R6 при k = 1, 2, . . . , p (шаги с R2 по R6 составляют один ”просмотр”) и завершить работу алгоритма. Переменная P будет указывать на запись с наименьшим ключом, LINK(P)—а запись со следующим по величине ключом, LINK(LINK(P))—на следующую и т.д.; поле LINK последней записи будет равно Λ.
R2 [Опустошить стопки.] При 0 ≤ i < M установить TOP[i] ← LOC(BOTM[i]) и BOTM[i] ← Λ.
R3 [Выделить k-ю цифру ключа.] Пусть KEY(P) — ключ записи, на которую указывает P,— равен (ap , . . . , a2 , a1 ); установить i ← ak , k-я младшая цифра этого ключа.
R4 [Скорректировать связи.] Установить LINK(TOP[i]) ← P, затем TOP[i] ← P.

R5 [Перейти к следующей записи.] Если k = 1 (первый просмотр) и если P = LOC(Rj ) при некотором j = 1, то установить P ← LOC(Rj−1 ) и возвратиться к шагу R3. Если k > 1 (не первый просмотр), то установить P ← LINK(P) и возвратиться к R3, если P = Λ.
R6 [Выполнить алгоритм H.] (Теперь мы уже распределили все элементы по стопкам.) Выполнить приведенный ниже алгоритм H, который сцепляет отдельные ”стопки” в один список, подготавливая их к следующему просмотру. Затем установить P ← BOTM[0], указатель на первый элемент объединенного списка.

Алгоритм H. (Сцепление очередей.)
H1 [Начальная установка.] Установить i ← 0.
H2 [Указатель на вершину стопки.] Установить P ← TOP[i].
H3 [Следующая стопка.] Увеличить i на 1. Если i = M , то установить LINK(P) ← Λ и завершить работу алгоритма.
H4 [Стопка пуста?] Если BOTM[i] = Λ, тo возвратиться к HЗ.
H5 [Сцепить стопки.] Установить LINK(P) ← BOTM[i]. Возвратиться к H2.


а вот код

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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include <stddef.h>
#include<iostream>
#include <stdlib.h>
using namespace std;
 
struct Elem 
{
    int *key;
    Elem *Link;
    Elem() 
   {
        this->Link = NULL;
        this->key = NULL;
    }
};
int main() 
{
    int n;    
    cout << "vvedite kol-vo zapisey" << endl;
    cin >> n;
    Elem *R;
    R = new Elem[n + 1];
    cout << "vvedite kolithestvo bukv v kazdom slove" << endl;
    int t;
    cin >> t;
    cout << "vvedite slova" << endl;
    for (int i = 1; i < n + 1; i++) 
   {
        R[i].key = new int[t + 1];
        for (int j = 1; j < t + 1; j++)
       {
            cin >> R[i].key[j];
       }
    }
    Elem *P;
    Elem **Top;
    Top=new Elem* [10];
    Elem **Botm=new Elem* [10];
    P = &R[n];
    for (int k = 1; k < t + 1; k++) 
    {
        for(int i=0;i<10;i++)
         {            
            Top[i]=(Elem*)&Botm[i];
            Botm[i]=NULL;
         }
R3:
        int i = P->key[t + 1 - k];
        Top[i]->Link = P;
        Top[i] = P;
        if (k == 1) 
        {
            int j = n;
            while ((P != &R[j]) && (j > 0)) 
            {
                j--;
            }
            if ((j!=1) && (P == &R[j])) 
           {
                P = &R[j - 1];
                goto R3;
           }
         } else 
          {
            P = P->Link;
            if (P != NULL) 
            {
             goto R3;
            }
          }
        int ii = 0;
H2:
        P = Top[ii];
H3:
        ii++;
        if (ii == 10) 
        {
            P->Link = NULL;
            goto STOP;
        }
        if (Botm[ii] == NULL) 
         {
            goto H3;
         }
        P->Link = Botm[ii];
        goto H2;
STOP:
                P = Botm[0];
     }
    while (P != NULL) 
    {
        for (int i = 1; i < t + 1; i++) 
        {
            cout << P->key[i];
        }
        cout << endl;
        P = P->Link;
    }
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2012, 15:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос исправите ошибку (C++):

исправите ошибку - C++
#include &lt;iostream&gt; #inclide &lt;math&gt; int main() { int a, s, r; cout&lt;&lt;&quot;a=&quot;; cin&gt;&gt;a; if (a&gt;0) { r =...

исправите,пожалуйста!! - C++
помогите,нужно написать прогу,чтоб каждый отрицательный элемент последовательности заменить на его квадрат #include&lt;iostream&gt; ...

исправите,пожалуйста!! нужно чтоб считало функцию cos√(x) косинус корня из Х - C++
#include&lt;iostream&gt; #include&lt;conio.h&gt; #include&lt;math.h&gt; using namespace std; void main() { setlocale(LC_ALL,&quot;Russian&quot;); ...

Подскажите как исправить ошибку. прога ломается на 79 строке. а ошибку не выдает - C++
#include &lt;iostream&gt; #include &lt;cstdlib&gt; #include &lt;ctime&gt; using namespace std; int chisla(int a,int b) { ...

Найти ошибку в программе: в visual studio выдает ошибку - C++
#include &lt;math.h&gt; #include &lt;conio.h&gt; #include &lt;iostream&gt; using namespace std; int main() { double x, E, ypred, y, S; ...

Ребят Незнаю что делать при запуске на компилирование выдает ошибку.Кто понимает что не так скажите а если не затруднит исправьте ошибку - C++
Разговаривал с двумя преподами говорят что проект не правильно создавал,хотя все правильно из группы спрашивал у парней говорят что не...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.05.2012, 15:57
Привет! Вот еще темы с ответами:

выдаёт ошибку в составленной программе выдаёт ошибку - C++
Составить программу, которая находит максимальное значение среди элементов линейной таблицы Y, состоящий из N действительных чисел, имеющих...

Исправите ошибку... - C++ Builder
помогите, пожалуйста, исправить ошибку.... void __fastcall TForm1::btnAddTownClick(TObject *Sender) { if...

Исправите пожалуйста ошибку - Delphi
Unit1.pas(52): E2065 Unsatisfied forward or external declaration: 'TNewThread.Sync'

исправите ошибку в прогрпме - MathCAD
Помогите исправить ошибку


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru