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

Проверить использование операции декремента для итератора

08.06.2020, 01:44. Показов 1062. Ответов 2

Author24 — интернет-сервис помощи студентам
ИТЕРАТОР. Распечатать свой массив - вектор с помощью итератора (Iter) и операции
инкремента (++) для итератора. Проверить использование операции декремента для итератора.
Как вообще проверить использование операции декремента для итератора??

C++
1
2
3
4
5
6
7
8
cout << "Пункт 4.7" << endl;
        vector<int>::iterator iter;
 
        cout << "Распечатка массива karpov с помощью итератора: " << endl;
        int i;
        for (i = 0, iter = karpov.begin(); iter != karpov.end(); iter++, i++) {
            cout << "karpov[" << i << "] = " << *iter << endl;
        }
Сам целый код вот:
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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
#define _AFXDLL
#include "afx.h"
#include <iostream>
#include <string>
#include <iomanip>
#include <fstream>
#include <cstdlib>
#include <string>
#include <limits>
#include<windows.h>
#include <vector>
#include <atlcoll.h> 
#include <new>
#include <time.h>
using namespace std;
//функция распечатки массива vector
void print_vect(vector<int>& kar) {
    for (int i = 0; i < (int)kar.size(); i++) {
        cout << "vect[" << i << "] = " << kar[i] << endl;
    }
}
void pvect_iter(vector<int>& kar) {
    vector<int>::iterator iter;
 
    int i;
    for (i = 0, iter = kar.begin(); iter != kar.end(); iter++, i++) {
        cout << "vect[" << i << "] = " << *iter << endl;
    }
}
class Triangle {
public:
    int a, b, c, d;
 
    Triangle() : a(0), b(0), c(0), d(0) {}
    Triangle(int a, int b, int c, int d) : a(a), b(b), c(c), d(d) {}
    void Print() {
        cout << "(" << a << ", " << b << ", " << c << ", " << d << ")" << endl;
    }
    friend ostream& operator <<(ostream& out, Triangle obj);
};
ostream& operator <<(ostream& out, Triangle obj) {
    return out << "(" << obj.a << ", " << obj.b << ", " << obj.c << ", " << obj.d << ")" << endl;
}
 
void print_rect(vector<Triangle> v) {
    vector<Triangle>::iterator itercl;
    int i;
    for (i = 0, itercl = v.begin(); itercl != v.end(); itercl++, i++) {
        cout << "vect[" << i << "] = " << *itercl;
    }
}
 
class Triangle1 : public CObject {
public:
    int a, b, c, d;
 
    Triangle1() : a(0), b(0), c(0), d(0) {}
    Triangle1(int a, int b, int c, int d) : a(a), b(b), c(c), d(d) {}
    void Print() {
        cout << "(" << a << ", " << b << ", " << c << ", " << d << ")" << endl;
    }
    friend ostream& operator <<(ostream& out, Triangle1 obj);
};
 
 
ostream& operator <<(ostream& out, Triangle1 obj) {
    return out << "(" << obj.a << ", " << obj.b << ", " << obj.c << ", " << obj.d << ")" << endl;
}
 
using namespace std;
int main()
{
 
    system(" chcp 1251 > nul");
    char SW;
 
 
    vector<int> karpov;
    karpov.push_back(1);
    karpov.push_back(2);
    karpov.push_back(3);
    karpov.push_back(4);
    karpov.push_back(5);
 
    vector<Triangle> VECT;
    Triangle r1;
    VECT.push_back(r1);
    Triangle r2(11, 12, 13, 14);
    VECT.push_back(r2);
    Triangle r3(21, 22, 23, 24);
    VECT.push_back(r3);
    Triangle r4(31, 32, 33, 34);
    VECT.push_back(r4);
    VECT.push_back(*new Triangle(4, 3, 2, 1));
 
    CObArray arr;
    arr.Add(new Triangle1);
    arr.Add(new Triangle1(1, 2, 3, 4));
    arr.Add(new Triangle1(21, 22, 23, 24));
    arr.Add(new Triangle1(31, 32, 33, 34));
    arr.Add(new Triangle1(4, 3, 2, 1));
 
 
MENU:;
    system("  CLS");
    printf("1. Пункт 4.5 \n");
    printf("2. Пункт 4.6 \n");
    printf("3. Пункт 4.7 \n");
    printf("4. Пункт 4.8 \n");
    printf("5. Пункт 4.9 \n");
    printf("6. Пункт 4.10 \n");
    printf("7. Пункт 4.11 \n");
    printf("8. Пункт 4.12 \n");
    printf("9. Пункт 4.13 \n");
    printf("a. Пункт 4.14 \n");
    printf("b. Пункт 4.15 \n");
    printf("c. Пункт 4.16 \n");
    printf("e. Выход ...\n");
    printf("0. Меню ...\n");
 
    // ...
    // выбрать нужный пункт меню
    printf("Выберете пункт меню:\n");
    SW = getchar(); // Ввод нажатой клавиши 
    // Переключатель
    //Группа: ИУ5-22
    //тип функции для параметров умолчания: минимум
    //Тип функции для перегрузки функций: среднее
    //Тип класса для перегрузки операций Complex
    //Тип операции для перегрузки ввода и вывода
    switch (SW)
    {
    case'1':
    {
        cout << "Пункт 4.5" << endl;
        //4.4
        cout << "Распечатка массива karpov: " << endl;
        for (int i = 0; i < (int)karpov.size(); i++) {
            cout << "karpov[" << i << "] = " << karpov[i] << endl;
        }
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'2':
    {
        cout << "Пункт 4.6" << endl;
        cout << "Распечатка массива karpov: " << endl;
        print_vect(karpov);
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
 
    }
    case'3':
    {
        cout << "Пункт 4.7" << endl;
        vector<int>::iterator iter;
 
        cout << "Распечатка массива karpov с помощью итератора: " << endl;
        int i;
        for (i = 0, iter = karpov.begin(); iter != karpov.end(); iter++, i++) {
            cout << "karpov[" << i << "] = " << *iter << endl;
        }
 
        vector<int>::reverse_iterator riter;
 
        cout << "\nРаспечатка массива karpov с помощью реверсивного итератора: " << endl;
        for (i = 0, riter = karpov.rbegin(); riter != karpov.rend(); riter++, i++) {
            cout << "karpov[" << i << "] = " << *riter << endl;
        }
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'4':
    {
        cout << "Пункт 4.8" << endl;
        cout << "Распечатка массива karpov с итератором с помощью функции: " << endl;
        pvect_iter(karpov);
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'5':
    {
        cout << "Пункт 4.9" << endl;
        karpov.insert(karpov.end(), 6);
        cout << "Добавление элемнета в конец массива karpov: " << endl;
        pvect_iter(karpov);
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'6':
    {
        cout << "Пункт 4.10" << endl;
        cout << "Удаление первого элемента массива: " << endl;
        karpov.erase(karpov.begin() + 1);
        pvect_iter(karpov);
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'7':
    {
        cout << "Пункт 4.11" << endl;
 
        cout << "Проверка пустого массива перед удалением: " << endl;
        if (karpov.empty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
 
        cout << "Проверка пустого массива после удаления: " << endl;
        karpov.erase(karpov.begin(), karpov.end());
        if (karpov.empty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
 
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'8':
    {
        cout << "Пункт 4.12" << endl;
        cout << "Распечатка своего массива Triangle: " << endl;
        for (int i = 0; i < (int)VECT.size(); i++) {
            cout << "karpov[" << i << "] = " << VECT[i];
        }
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'9':
    {
        cout << "Пункт 4.13" << endl;
 
        cout << "Распечатка массива VECT: " << endl;
        for (int i = 0; i < (int)VECT.size(); i++) {
            cout << "vect[" << i << "] = " << VECT[i];
        }
 
        cout << "Распечатка массива VECT с помощью итератора: " << endl;
        vector<Triangle>::iterator itercl;
        int i;
        for (i = 0, itercl = VECT.begin(); itercl != VECT.end(); itercl++, i++) {
            cout << "vect[" << i << "] = " << *itercl;
        }
 
        cout << "Распечатка массива VECT с помощью обратного итератора: " << endl;
        vector<Triangle>::reverse_iterator ritercl;
        for (i = 0, ritercl = VECT.rbegin(); ritercl != VECT.rend(); ritercl++, i++) {
            cout << "vect[" << i << "] = " << *ritercl;
        }
 
        cout << "Добавление элемента на вторую позицию в массив VECT: " << endl;
        VECT.insert(VECT.begin() + 2, *new Triangle(5, 5, 5, 5));
        for (i = 0, itercl = VECT.begin(); itercl != VECT.end(); itercl++, i++) {
            cout << "vect[" << i << "] = " << *itercl;
        }
 
        cout << "Удаление элемента на второй позиции в массиве VECT: " << endl;
        VECT.erase(VECT.begin() + 2);
        for (i = 0, itercl = VECT.begin(); itercl != VECT.end(); itercl++, i++) {
            cout << "vect[" << i << "] = " << *itercl;
        }
 
        cout << "Проверка пустого массива перед удалением: " << endl;
        if (VECT.empty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
 
        cout << "Проверка пустого массива после удаления: " << endl;
        VECT.erase(VECT.begin(), VECT.end());
        if (VECT.empty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'a':
    {
        cout << "Пункт 4.14" << endl;
        cout << "Функция распечатки массива : VECT" << endl;
        print_rect(VECT);
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'b':
    {
        cout << "Пункт 4.15" << endl;
        cout << "Распечатка массива arr класса Triangle1: " << endl;
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
    case'c':
    {
        cout << "Пункт 4.16" << endl;
 
        cout << "Распечатка массива arr: " << endl;
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
 
        cout << "Получение второго элемента: " << endl;
        Triangle1* elem = (Triangle1*)(arr.GetAt(2));
        cout << "elem = ";
        elem->Print();
 
        cout << "Замена третьего элемента в массиве: " << endl;
        arr.SetAt(3, new Triangle1);
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
 
        cout << "Вставка элемента: " << endl;
        arr.InsertAt(3, new Triangle1(4, 4, 4, 4));
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
 
        cout << "Удаление нового элемента: " << endl;
        arr.RemoveAt(1);
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
 
        cout << "Добавление массива arr в массив arr1: " << endl;
        CObArray arr1;
        arr1.Add(new Triangle1(1, 1, 1, 1));
        arr1.Append(arr);
        for (int i = 0; i < arr1.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr1[i]);
            cout << "arr1[" << i << "] =";
            r->Print();
        }
 
        cout << "Копирование массива arr1 в массив arr: " << endl;
        arr.Copy(arr1);
        for (int i = 0; i < arr.GetCount(); i++) {
            Triangle1* r = (Triangle1*)(arr[i]);
            cout << "arr[" << i << "] =";
            r->Print();
        }
 
        cout << "Проверка пустого массива перед удалением: " << endl;
        if (arr.IsEmpty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
 
        cout << "Проверка пустого массива после удаления: " << endl;
        arr.RemoveAll();
        if (arr.IsEmpty())
            cout << "массив пуст" << endl;
        else
            cout << "в массиве есть элементы" << endl;
 
        
        system(" PAUSE");
        SW = getchar();
        goto MENU;
        goto MENU;
        break;
        break;
    }
 
    }
 
    system(" PAUSE");
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.06.2020, 01:44
Ответы с готовыми решениями:

Перегрузка операции для итератора
Здравствуйте, назрела такая проблема - не перегружается оператор или я неправильно использую перегрузку - 3 дня мучаюсь, уже надоедает,...

Использование потокового итератора для пользовательских обьектов
Надо с помощю итератора ofstream_iterator вывести содержимое множины, в которой есть обьекты пользовательського типа. Вот что я пока...

Префиксные и постфиксные операции инкремента и декремента + наследование
Дано: Два класса(Counter и CountDn), следует при помощи наследования добавить функцию постфиксных операций. На то, что я набросал выдает...

2
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
08.06.2020, 01:51 2
Лучший ответ Сообщение было отмечено karpovigor как решение

Решение

Цитата Сообщение от karpovigor Посмотреть сообщение
Как вообще проверить использование операции декремента для итератора??
использовать декремент, а потом проверить сработало ли (можно сравнить новый адрес и старый) ну или просто "не крашнулось - значит работает"

Добавлено через 48 секунд
можете сделать тоже самое что вы делали с инкрементом, только на дикременте

Добавлено через 1 минуту
C++
1
2
for (i = std::distance(karpov.begin(), karpov.end()), iter = karpov.end(); iter != karpov.begin(); iter--, i--) {
            cout << "karpov[" << i << "] = " << *iter << endl;
0
0 / 0 / 0
Регистрация: 24.09.2019
Сообщений: 5
09.06.2020, 00:06  [ТС] 3
AndryS1, спасибо огромное!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.06.2020, 00:06
Помогаю со студенческими работами здесь

Операции инкремента и декремента (префиксная и постфиксная версия). Подскажите.
#include &lt;iostream&gt; #include &lt;string&gt; using namespace std; int main () { setlocale(LC_ALL,...

Использование инкремента(Декремента)
Есть три кнопки и три индикатора(лампочки). Если нажимаю кнопку-1 тогда включается лампочка нажимаю еще раз выключается. Если по одному...

Написать программу, которая демонстрирует разницу между операциями пре-декремента и пост-декремента
Написать программу, которая демонстрирует разницу между операциями переддекремента и постдекремента. Занести ее в тетрадь с пояснениями.

Безопасное использование итератора С++
перебираем в цикле контейнер: for (auto it = A.begin(); it != A.end(); ++it) потом где то внутри удаляем его элемент, при чем не...

Объявление итератора и его использование
Как правильно объявлять итератор? В каких случаях используется? Можно ли через итератор получить доступ к элементу вектора(записать,...


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Что нового в C# 14
UnmanagedCoder 10.03.2025
Предстоящая версия C# 14 обещает принести изменения, которые сделают разработку еще более приятной и эффективной. Что стоит отметить, так это влияние сообщества разработчиков на формирование новых. . .
Формулы поворота
Igor3D 10.03.2025
Добрый день Тема Эти формулы приводятся во множестве тьюториалов, часто под видом "матрица вращения на плоскости". x' = x * cos(a) - y * sin(a) y' = y * cos(a) + x * sin(a) Как бы Вы их. . .
Что нового в .NET 10
UnmanagedCoder 10.03.2025
. NET 10 выходит как релиз с длительной поддержкой (LTS), включающей три года обновлений. В этом обновлении Microsoft сфокусировались на нескольких направлениях: производительность, оптимизация. . .
Отложенное высвобождение, RCU и Hazard Pointer в C++26
NullReferenced 09.03.2025
Многопоточное программирование стало важной частью современной разработки. Когда несколько потоков одновременно работают с общими данными, возникает целый ряд проблем, связанных с синхронизацией и. . .
Неблокирующийся стек на C++26
NullReferenced 09.03.2025
Традиционные способы синхронизации в многопоточном программировании — мьютексы, семафоры, условные переменные — часто превращаются в узкое место в плане производительности. При этом неблокирующиеся. . .
Обработка строк в C++26: Новые возможности string и string_view
NullReferenced 09.03.2025
Новый стандарт C++26 предлагает много улучшений для работы с привычными string и относительно новыми string_view. string_view - это невладеющая ссылка на последовательность символов, появившаяся в. . .
Мой первый аддон для Blender 3D, с помощью нейронки (не зная даже азов пайтона, но это не значит что так и с остальным).
Hrethgir 09.03.2025
Потратил весь день. Пол-дня мне хватило, чтобы понять что с версией с 14B мне не одолеть написание функционального кода, на языке с которым я вообще никак не знаком - пайтон. Версия 22B от другого. . .
Einstein@Home сегодня исполняется двадцать лет!
Programma_Boinc 09.03.2025
Einstein@Home сегодня исполняется двадцать лет! Отправлено 19 февраля 2025 года в 17:20:21 UTC Я хочу поздравить всех наших волонтеров, разработчиков и ученых из Einstein@Home. Мы официально. . .
Заполнители и расширенный набор символов в C++26
NullReferenced 09.03.2025
C++26 представляет два важных обновления: заполнители и расширенный набор символов. Заполнители (placeholders) решают давнюю проблему лаконичности кода в шаблонных выражениях и лямбда-функциях. Они. . .
Контракты в C++26
NullReferenced 09.03.2025
Контракты – это механизм, позволяющий указывать предусловия, постусловия и инварианты для функций в коде. Эта функциональность должна была стать частью C++20, но была исключена на встрече комитета. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru