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

Непонятный код

16.05.2020, 15:26. Показов 1684. Ответов 2
Метки c++ (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет
Делаю задание
И для проверки нашел код который написал сам создатель задания и я не понял одну часть кода.
Вот она
C++
1
2
3
4
5
6
7
8
9
            for (string& s : v) {
                cin >> s;
                vector<string> v2;
                v2.push_back(bus);
                if (stops.count(s)) {
                    stops[s].insert(end(stops[s]), begin(v2), end(v2));
                } else {
                    stops[s] = v2;
                }
Непонятно мне что тут делает вектор v2 и insert.
Уже неделю парюсь с этим вопросом(

Вот весь код

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
int main() {
    int q;
    cin >> q;
    map<string, vector<string>> buses;
    map<string, vector<string>> stops;
    
    for (int i = 0; i < q; ++i) {
        string operation_code;
        cin >> operation_code;
        if (operation_code == "NEW_BUS") {
            string bus;
            int stop_count;
            cin >> bus;
            cin >> stop_count;
            vector<string> v(stop_count);
            for (string& s : v) {
                cin >> s;
                vector<string> v2;
                v2.push_back(bus);
                if (stops.count(s)) {
                    stops[s].insert(end(stops[s]), begin(v2), end(v2));
                } else {
                    stops[s] = v2;
                }
            }
            buses[bus] = v;
        } else if (operation_code == "BUSES_FOR_STOP") {
            string stop;
            cin >> stop;
            if (stops[stop].size() == 0) {
                cout << "No stop" << endl;
                stops.erase(stop);
            } else {
                for (const auto& item : stops) {
                    if (item.first == stop) {
                        for (string w : item.second) {
                            cout << w << " ";
                        }
                        cout << endl;
                    }
                }
            }
        } else if (operation_code == "STOPS_FOR_BUS") {
            string bus;
            cin >> bus;
            if (buses.count(bus) > 0) {
                for (const auto& item : buses) {
                    if (item.first == bus) {
                        for (string w : item.second) {
                            cout << "Stop " << w << ": ";
                            for (const auto& item2 : stops) {
                                if (item2.first == w) {
                                    if (item2.second.size() == 1) {
                                        cout << "no interchange" << endl;
                                    } else {
                                        for (string w2 : item2.second) {
                                            if (w2 != bus) {
                                                cout << w2 << " ";
                                            }
                                        }
                                        cout << endl;
                                    }
                                }
                            }
                        }
                    }
                }
            } else {
                cout << "No bus" << endl;
            }
        } else if (operation_code == "ALL_BUSES") {
            if (buses.size() == 0) {
                cout << "No buses" << endl;
            } else {
                for (const auto& item : buses) {
                    cout << "Bus " << item.first << ": ";
                    for (string w : item.second) {
                        cout << w << " ";
                    }
                    cout << endl;
                }
                cout << endl;
            }
        }
    }
    
    return 0;
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.05.2020, 15:26
Ответы с готовыми решениями:

Непонятный Код
К какому языку относится следующий код: use Net::SSH2; my $user = &quot;root&quot;; my $pass = &quot;yahh&quot;; my $ip = &quot;127.0.0.1&quot;;...

Непонятный код
#define HEX__(n) 0x##n##LU #define B8__(x) ((x&amp;0x0000000FLU)?1:0)\ +((x&amp;0x000000F0LU)?2:0)\ ...

Непонятный код
ifstream i(file); cout &lt;&lt; &quot;\nПрочитаем содержимое файла &quot; &lt;&lt; file &lt;&lt; endl; while(true) { getline(i, out_s); ...

2
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,818
16.05.2020, 16:04
Лучший ответ Сообщение было отмечено D_DWow как решение

Решение

D_DWow, автор этого кода страдает ерундой. Смысл этих действий такой:
Если в map stops присутствует ключ s, то он добавляет содержимое вектора v2 в конец соответствующего ключу вектора в stops. Т.к. в v2 всегда только один элемент, то добавляться в конец тоже всегда будет только один элемент.
Если в map stops отсутствует ключ s, то он добавляется, а его значением назначается копия вектора v2 (которая, как мы помним, содержит только один элемент).
1
1 / 1 / 0
Регистрация: 02.01.2020
Сообщений: 25
16.05.2020, 17:37  [ТС]
Аааа)
Ну там вроде в задачи надо было сделать так, что бы у одного автобуса небыли повторяющихся остановок.
В целом код странный.

Но большое спасибо за разъяснение)
Я этим insert всегда в ступор вхожу. Ни как не пойму как он с этими итераторами работает.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.05.2020, 17:37
Помогаю со студенческими работами здесь

Непонятный код?
Подскажите, что выполняется в следующем коде и каким образом? int main() { char buf; while ( cout &lt;&lt;...

Непонятный код с FreeLibrary
static int open_gl(void) { libGL = LoadLibraryW(L&quot;opengl32.dll&quot;); if(libGL != NULL) { gladGetProcAddressPtr =...

Непонятный код и функция FindWindow
Есть код: CWnd* pWnd = CWnd::FindWindow(&quot;XLMAIN&quot;, NULL); if (pWnd != NULL) { TRACE(&quot;Excel window found\n&quot;); ...

Непонятный код в книге Страуструпа
Периодически встречаются ошибки. Это тоже, или какой-то синтаксис (Скачал бесплатную VS - не компилируется). Есть подозрение, что это...

Код выдает непонятный результат -1.#IND
#include&lt;stdio.h&gt; #include &lt;math.h&gt; #include &lt;iostream&gt; int main() { int a=-2,b=6; double x=-2,y=0,c=0.5; do { ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru