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

Контейнер queue

06.05.2020, 15:40. Показов 933. Ответов 1

Студворк — интернет-сервис помощи студентам
Добрый день, есть такой код, хотелось бы сделать его на STL библиотеке queue а не на стеке, можете прокомментировать этот код, или подсказать что на что заменить для queue :
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
struct Elem {
    int val;
    Elem* pr;
};
struct Stack {
    Elem* up;
    Stack() {
        up = NULL;
    }
    void push(int a) {
        Elem* tmp;
        tmp = new Elem();
        tmp->val = a;
        tmp->pr = up;
        up = tmp;
    }
    int pop() {
        if (up != NULL) {
            int v = up->val;
            Elem* tmp = up;
            up = up->pr;
            delete tmp;
            return v;
        }
        else {
            cout << "empty stack" << endl;
            return 0;
        }
    }
    int back() {
        return up->val;
    }
    bool empty() {
        return up == NULL;
    }
    void free() {
        while (!empty()) pop();
    }
    ~Stack() {
        free();
    }
};
int N, k;
Stack cont[501];
int main() {
    setlocale(0, "");
    int tmp, i, j = 0, save = 1, qsave = 0;
    cout << "Входные данные : " << endl;
    cin >> N;
    save = 1;
 
    if (N == 2) {
        bool ok = true, first = true;
        cin >> k;
        if (k) {
            cin >> tmp;
            i = 1;
            while (tmp == 1 && i < k) {
                cin >> tmp;
                ++i;
            }
            j = tmp == 2;
            while (i < k) {
                cin >> tmp;
                if (tmp == 1) ok = false;
                ++j;
                ++i;
            }
        }
        cin >> k;
        if (k) {
            cin >> tmp;
            i = 1;
            while (tmp == 2 && i < k) {
                cin >> tmp;
                ++i;
            }
            if (j && tmp == 1) ok = false;
            else if (tmp == 1) first = false;
            j += tmp == 1;
 
            while (i < k) {
                cin >> tmp;
                if (tmp == 2) ok = false;
                ++j;
                ++i;
            }
        }
        if (ok) {
            if (first)
                for (i = 0; i < j; ++i)
                    cout << "1 2" << endl;
            else
                for (i = 0; i < j; ++i)
                    cout << "2 1" << endl;
        }
        else cout << 0;
        return 0;
    }
 
    for (i = 1; i <= N; ++i) {
        cin >> k;
        if (k) {
            cin >> tmp;
            j = 1;
            while (tmp == i && j < k) {
                cin >> tmp;
                ++j;
            }
            if (tmp != i) cont[i].push(tmp);
 
            while (j < k) {
                cin >> tmp;
                cont[i].push(tmp);
                ++j;
            }
        }
    }
 
    cout << "Выходные данные : " << endl;
    for (i = 1; i < N; ++i) {
        while (!cont[i].empty()) {
            while (!cont[i].empty() && cont[cont[i].back()].empty()) {
                cout << i << " " << cont[i].pop() << endl;
            }
 
            while (!cont[i].empty() && !cont[cont[i].back()].empty()) {
                cout << i << " " << N << endl;
                cont[N].push(cont[i].pop());
            }
        }
 
        while (!cont[i].empty()) {
            cout << i << " " << N << endl;
            cont[N].push(cont[i].pop());
        }
    }
 
    while (!cont[N].empty()) {
        tmp = cont[N].pop();
        if (tmp == N) {
            cout << N << " " << save << endl;
            ++qsave;
        }
        else if (tmp == save) {
            save = 1 + save % 2;
            for (i = 0; i < qsave; ++i) {
                cout << tmp << " " << save << endl;
            }
            cout << N << " " << tmp << endl;
        }
        else {
            cout << N << " " << tmp << endl;
        }
    }
    for (i = 0; i < qsave; ++i) {
        cout << save << " " << N << endl;
    }
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.05.2020, 15:40
Ответы с готовыми решениями:

контейнер queue
здравствуйте , хотелось бы узнать как полечить доступ к элементам контейнера queue и как вывести элементы этого контейнера) помогите плиз)

Заменить контейнер vector, использовавшийся для хранения текстовых строк (листинг 2.3), на контейнер list
Здравствуйте форумчане, может кто объяснить как делать это задание и что собственно мы тут вообще делаем. сам листинг 2.3 ниже ...

Error C2664: Client::First: невозможно преобразовать параметр 1 из "std::queue<_Ty>" в "std::queue<_Ty> &"
barbershop.h: #ifndef __BARBERSHOP_H__ #define __BARBERSHOP_H__ #include &lt;vector&gt; #include &lt;queue&gt; #include &quot;wantshaircut.h&quot; ...

1
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
06.05.2020, 15:43
Цитата Сообщение от origami111 Посмотреть сообщение
или подсказать что на что заменить для queue
вот интерфейс очереди, этой документации должно быть достаточно для исправления твое кода.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.05.2020, 15:43
Помогаю со студенческими работами здесь

Where is a mistake in a queue?
Hello? help, please: #include&lt;iostream&gt; #include&lt;iomanip&gt; using namespace std; template &lt;typename T&gt; struct Queue { ...

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

Queue сортировка
Задание : отсортировать чергу по возростанию не использевать ООП queue &lt;int&gt; q; sort(q.front();q.back()) // не пашет подскажите...

Функция print() в queue
Здравствуйте, помогите реализовать вывод очереди в файл. Вот код, не понимаю как реализовать функцию print(), чтобы она вывела тип...

Контейнерный класс Queue
Создать абстрактный базовый класс с виртуальной функцией - сумма прогрессии. Создать производные классы: арифметическая прогрессия и...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru