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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ как увидеть cout от диконстрактора (компелятор MS V C++ 2010 express ) http://www.cyberforum.ru/cpp-beginners/thread577690.html
Кочется увидеть cout от деконстрактора // .h #ifndef SILLY_H #define SILLY_H #include <iostream>
C++ Удаление элементов Ребят, помогите написать метод удаления для класса хеш таблица, я написал,но что то не работает, вот код: #include <iostream> #include <conio.h> #include <stdlib.h> #define SIZE 25 using namespace std; http://www.cyberforum.ru/cpp-beginners/thread577682.html
Статический метод и объекты C++
Есть класс А с полями, методами и один статический метод. Как мне через этот статический метод обратиться сразу ко всем объектам этого класса, а точнее к Method1()? class A { public: int i; void Method1(){}; void Method2(){};
C++ Имитация Алгоритма планирования процессов First-Come, First-Served (FCFS)
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <math.h> typedef struct { int p_no; short burst; short wait; short r_times; // number of CPU processes
C++ Построить вектор, каждый элемент которого равен количеству равных элементов в соответствующей строке матрицы http://www.cyberforum.ru/cpp-beginners/thread577670.html
Помогите решить задачку ребят. Буду очень признателен Дана матрица А(nxn). Построить вектор, каждый элемент которого равен количеству равных элементов в соответствующей строке матрицы А. Воспользоваться функцией, которая определяет это количество в i-ой строке матрицы А. немогу никак написать программу
C++ Перенос первой буквы каждого слова в конец Господа, помогите пожалуйста с задачей: В произвольном тексте (взятом из файла), содержащем не более 10 строк, в каждой строке не более 80 смволов, перенести первую букву каждого слова в его конец. Отсортировать строки в порядке убывания количества слов. Вывести полученный текст на экран. Выведенную информацию продублировать в текстовый файл, имя которого задаёт пользователь подробнее

Показать сообщение отдельно
Irishka_23
Сообщений: n/a
17.05.2012, 15:57     исправите ошибку
вот алгоритм
Программа реализует алгоритм 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru