С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
Другие темы раздела
C++ Чтение структур с файла https://www.cyberforum.ru/ cpp-beginners/ thread1675473.html
Я записал структуру в файл! В файле лежит структура троих студентов. Как мне вывести из файла данные например для второго студента? Читал что-то про seekg() и tellg() но ничего не понял. Помогите пожалуйста!
C++ Как написать программу которая будет запускаться автоматически каждых 108 минут?
Как написать программу которая будет запускаться автоматически каждых 108 минут? Нужно что бы на экране появлялась консоль каждых 108 минут, и что бы её закрыть и продолжить работу нужно ввести числа "4 8 15 16 23 42" без скобок и запятых. Если что то будет не понятным, напишу более детально
C++ Как происходит ввод и обработка символов из консоли? https://www.cyberforum.ru/ cpp-beginners/ thread1675455.html
Приветствую, не могли бы вы мне подсказать на счет одной вещи. В книге Страуструпа есть реализация калькулятора, которая основана на том, что программа сначала анализирует все символы, принимает решение о первичности вычислений и вычисляет. class Token { public: char kind; // what kind of token double value; // for numbers: a value Token(char ch) // make a Token...
C++ Сортировка заданного фрагмента матрицы https://www.cyberforum.ru/ cpp-beginners/ thread1675443.html
Доброго времени суток. Собственно мой вопрос заключается больше не в том, как конкретно сделать, а что надо сделать(если это имеет какой-то смысл). Задание озвучено следующим образом: Реализовать сортировку матрицы по убыванию методом обмена с флагом перестановки(это так изящно назван метод "пузырька" с флагом, я так понимаю) и применить его для указанных фрагментов числовой матрицы(вот...
Задать порядок байтов C++
Нет ли в C++ какого-то штатного средства, позволяющего преобразовать порядок байт числа в "от старшего к младшему"? Понятно, что навелосипедить код меняющий байты местами не долго. Только этот велосипед может красочно перевернуться на машине использующей порядок "от старшего к младшему" изначально. И вообще, хотелось бы без велосипедов.
C++ Как класс string записать в бинарный файл через вектор? https://www.cyberforum.ru/ cpp-beginners/ thread1675409.html
вопрос такой у меня есть класс. я создаю вектор по этому классу vector<Employee> work; вектор отлично заполняется и вся программа хорошо работает. но когда я хочу применить const string BINAR_FILE = "binarfile"; ofstream fout(BINAR_FILE, ios::binary); for (int i = 0; i < Getcountwork(); ++i) {
C++ Создать текстовое меню, в котором при выборе первого пункта вычисляется значения квадрата введенного числа https://www.cyberforum.ru/ cpp-beginners/ thread1675395.html
Как создать текстовое меню, в котором при выборе первого пункта вычисляется значения квадрата введенного числа, при выборе второго пункта - значение куба и тд.
Программа аннотирования списка функций C++
ПАомогите, нужно сделать программу, которая должна построчно определять комментарии в стиле doxygen и при нахождении тега \func выводить описание функции в стандартный вывод. Я не прошу писать мне программу, подскажите, как это можно сделать. Заранее спасибо))
C++ По заданному номеру цвета радуги(числа от 1 до 7) вывести его название По заданному номеру цвета радуги(числа от 1 до 7) вывести его название(красный - фиолетовый) https://www.cyberforum.ru/ cpp-beginners/ thread1675380.html C++ Определение площади и длины радиуса круга https://www.cyberforum.ru/ cpp-beginners/ thread1675377.html
Помогитееее, срочно =) В первый ряд файла output.txt вывести площадь круга радиуса R. На второй строке вывести длину круга радиуса R. Тест будет засчитан, если все числа в выходном файле будут отличаться от точного не больше, чем на 10 в минус третьей степени.
C++ Определить является ли заданное число трёхзначным, если нет, вывести его последнюю цифру, а если да, первую
Помогите пожалуйста, срочно. Нужно определить является ли число трёхзначным, если нет, вывести его последнюю цифру, а если да, первую. Желательно реализовать через файлы. Пример: input.txt -> output.txt 15 -> 5 312 -> 222
C++ Отсортировать строки матрицы по количеству в них симметричных чисел https://www.cyberforum.ru/ cpp-beginners/ thread1675369.html
Задача: Отсортировать строки матрицы по количеству в них симметричных чисел. Заранее спасибо за ответ.
30 / 6 / 9
Регистрация: 23.03.2015
Сообщений: 508
03.03.2016, 16:05  [ТС] 0

Очистить поток std::stringstream - C++ - Ответ 8832542

03.03.2016, 16:05. Показов 15026. Ответов 66
Метки (Все метки)

Ответ

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
#include <iostream>
#include <conio.h>
#include <string>
#include <algorithm>
#include <ctype.h>
#include <sstream>
#include <map>
 
std::string rightPPF;
std::string leftPPF;
std::string resultLeft;
std::string resultRight;
 
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
 
void SetRussianLocale() { setlocale(LC_ALL, "Russian"); }
void tips();
void clearSpace();
void clearAbc();
 
 
int main() {
 
    SetRussianLocale();
    ////////////////////////////////////////////////////////////////////////////////////////////////////////
    tips();
    ////////////////////////////////////////////////////////////////////////////////////////////////////////
    ////////////////////////////////////////////////////////////////////////////////////////////////////
    clearAbc();
    std::stringstream ss_11(rightPPF);
    std::string s_11;
    std::stringstream ss_22(leftPPF);
    std::string s_22;
 
    while (!ss_11.eof()) {
 
        std::getline(ss_22, s_22, ',');
        std::getline(ss_11, s_11, ',');
        if (s_11.length() == 1) {
 
            if (s_22.length() == 1) {
                // zikl for
                if (s_22.find(s_11[0]) != std::string::npos) {
 
                    std::cout << leftPPF << "=>" << rightPPF << "\t - строка доказана" << std::endl;
                    break;
                }
                else {
                    std::cout << std::endl;
                    leftPPF.push_back(',');
                    leftPPF.push_back(s_11[0]);
                    size_t p1;
                    if (p1 = rightPPF.find(s_11[0]) != std::string::npos) {
 
                        rightPPF.erase(p1 - 1, 2);
                    }
                    //rightPPF.erase(rightPPF.begin());
                    //rightPPF.erase(rightPPF.begin());
                    std::cout << leftPPF << "=>" << rightPPF << "\tSwap";
                    break;
                }
            }
        }
    }
    ss_22.str(rightPPF);
    ss_22.clear();
    ss_11.str(rightPPF);
    ss_11.clear();
    
    std::stringstream ss_33(leftPPF);
    std::string s_33;
 
    while (!ss_33.eof()) {
 
        std::cout << "HIIIIII" << std::endl;
        std::cout << std::endl;
        std::getline(ss_33, s_33, ',');
 
        if (s_33.length() == 3) {
 
            std::cout << "TIIIII" << std::endl;
            std::cout << std::endl;
            if (leftPPF.find(s_33) != std::string::npos) {
 
                std::cout << std::endl;
                std::cout << s_33;
                std::cout << std::endl;
                if (rightPPF.find(s_33[0]) != std::string::npos) {
 
                    if (s_33[2] == toupper(s_33[2])) {
 
                        rightPPF.push_back(',');
                        rightPPF.push_back(tolower(s_33[2]));
                        leftPPF.push_back(',');
                        leftPPF.push_back(s_33[0]);
                        size_t p2;
                        if (p2 = leftPPF.find(s_33[0]) != std::string::npos) {
 
                            leftPPF.erase(p2 + 1, 4);
                        }
                    }
                    else {
 
                        rightPPF.push_back(',');
                        rightPPF.push_back(toupper(s_33[2]));
                        leftPPF.push_back(',');
                        leftPPF.push_back(s_33[0]);
                        size_t p3;
                        if (p3 = leftPPF.find(s_33[0]) != std::string::npos) {
 
                            leftPPF.erase(p3 + 1, 4);
                        }
                    }
                }
                else {
 
                    if (s_33[0] == toupper(s_33[0])) {
 
                        rightPPF.push_back(',');
                        rightPPF.push_back(tolower(s_33[0]));
                        leftPPF.push_back(',');
                        leftPPF.push_back(s_33[2]);
                        size_t p4;
                        if (p4 = leftPPF.find(s_33[0]) != std::string::npos) {
 
                            leftPPF.erase(p4 + 1, 4);
                        }
                    }
                    else {
 
                        rightPPF.push_back(',');
                        rightPPF.push_back(toupper(s_33[0]));
                        leftPPF.push_back(',');
                        leftPPF.push_back(s_33[2]);
                        size_t p5;
                        if (p5 = leftPPF.find(s_33[0]) != std::string::npos) {
 
                            leftPPF.erase(p5 + 1, 4);
                        }
                    }
                }
                std::cout << leftPPF << "=>" << rightPPF << "\tssss";
                std::cout << std::endl;
                clearAbc();
                break;
            }
        }
        else {
            std::stringstream ss_44(rightPPF);
            std::string s_44;
            std::stringstream ss_55(leftPPF);
            std::string s_55;
 
            while (!ss_44.eof()) {
 
                std::getline(ss_55, s_55, ',');
                std::getline(ss_44, s_44, ',');
                if (s_44.length() == 1) {
 
                    if (s_55.length() == 1) {
 
                        if (s_55.find(s_44[0]) != std::string::npos) {
 
                            std::cout << leftPPF << "=>" << rightPPF << "\t -Теорема доказана" << std::endl;
                            break;
                        }
                        else {
                            std::cout << std::endl;
                            std::cout << leftPPF << "=>" << rightPPF << "\t -Теорема опровергается" << std::endl;
                            break;
                        }
                    }
                }
            }
 
            ss_55.str(rightPPF);
            ss_55.clear();
            ss_44.str(rightPPF);
            ss_44.clear();
        }
    }
 
    std::cout << std::endl;
 
    std::cout << leftPPF << "=>" << rightPPF << "\tmain:end";
    ss_33.str(rightPPF);
    ss_33.clear();
    
 
    _getch();
    return 0;
}
 
 
void tips() {
 
    std::cout << "\t\t\t\tИнструкция юзера.\n";
    std::cout << "\t\t\t\t^ - конъюнкция\n";
    std::cout << "\t\t\t\tv - дизъюнкция\n";
    std::cout << "\t\t\t\t> - импликация\n";
    std::cout << "\t\t\t\t, - запятая\n";
    std::cout << "\t\t\t\tx - инверсия X\n";
    std::cout << "\t\t\t\t! - общая инверсия(перед формуло)\n";
    std::cout << " Пожалуйста, вводите символы латинских букв и изображенных логических операций!\n\n\n";
    //(A^B)v(C>D)~B^C
    // шаг 1!
    std::cout << "Введите значения по отношению!";
    std::cout << "\nВведите отношение слева: ";
    std::cin >> leftPPF;
    std::cout << "\nВведите отношение справа: ";
    std::cin >> rightPPF;
 
}
/////////////////////////////////////////////////////////////////////////////////////////////////////////
void clearSpace() {
 
    // исключение пробела
    for (unsigned int i = 0; i < leftPPF.length(); ++i)
 
        if (leftPPF[i] == ' ')
 
            leftPPF.erase(leftPPF.begin() + i);
 
    for (unsigned int j = 0; j < rightPPF.length(); ++j)
 
        if (rightPPF[j] == ' ')
 
            rightPPF.erase(rightPPF.begin() + j);
 
    std::cout << leftPPF << "=>" << rightPPF << "\tClearSpace";
    std::cout << std::endl;
}
 
void clearAbc() {
    // шаг 12!
    // первая строка
    std::stringstream ss_1(leftPPF);
 
    std::map<char, bool> chars_1;
    std::string s_1;
    while (!ss_1.eof()) {
 
        std::getline(ss_1, s_1, ',');
        if (s_1.length() == 1) {
 
            if (chars_1.find(s_1[0]) == chars_1.end())
 
                chars_1[s_1[0]] = false;
        }
        else /*if(s.lenght()==3*/ {
 
            chars_1[s_1[0]] = true;
            chars_1[s_1[2]] = true;
        }
    }
 
    ss_1.str(leftPPF);
    ss_1.clear();
 
 
    while (!ss_1.eof()) {
 
        std::getline(ss_1, s_1, ',');
        if (s_1.length() == 1) {
 
            if (chars_1[s_1[0]])
 
                continue;
            chars_1[s_1[0]] = true;
        }
        resultLeft += s_1 + ",";
    }
    if (resultLeft.length())
 
        resultLeft.resize(resultLeft.length() - 1);
    
    
    // вторая строка
    std::stringstream ss_2(rightPPF);
 
    std::map<char, bool> chars_2;
    std::string s_2;
    while (!ss_2.eof()) {
 
        std::getline(ss_2, s_2, ',');
        if (s_2.length() == 1) {
 
            if (chars_2.find(s_2[0]) == chars_2.end())
 
                chars_2[s_2[0]] = false;
        }
        else /*if(s.lenght()==3*/ {
 
            chars_2[s_2[0]] = true;
            chars_2[s_2[2]] = true;
        }
    }
    ss_2.str(rightPPF);
    ss_2.clear();
 
    while (!ss_2.eof()) {
 
        std::getline(ss_2, s_2, ',');
        if (s_2.length() == 1) {
 
            if (chars_2[s_2[0]])
 
                continue;
            chars_2[s_2[0]] = true;
        }
        resultRight += s_2 + ",";
    }
    if (resultRight.length())
 
        resultRight.resize(resultRight.length() - 1);
    
    leftPPF = resultLeft;
    rightPPF = resultRight;
    std::cout << resultLeft << "=>" << resultRight << "\tClearABC: r,r";
    std::cout << std::endl;
 
    std::cout << leftPPF << "=>" << rightPPF << "\tClearABC: l,f";
    std::cout << std::endl;
    
}
Добавлено через 47 секунд
здесь пока локально объявлены потомучто выдает ошибку.

Добавлено через 1 час 6 минут
Croessmah, так что? код выложил

Вернуться к обсуждению:
Очистить поток std::stringstream C++
0
Заказать работу у эксперта
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.03.2016, 16:05
Готовые ответы и решения:

Странное поведение std::string, полученного из std::stringstream
Есть код #include &lt;iostream&gt; #include &lt;sstream&gt; #include &lt;cstring&gt; int main() { ...

Std::stringstream
Добрый день! Я не понимаю почему я ввожу в поток std::stringstream три элемента, число, строку и...

std::stringstream precision
Как обрезать количество символов во входной строковой поток? к примеру: float a=4.768123;...

Как сделать std::stringstream
Как преобразовать из &quot;const char *&quot; в &quot;LPCWSTR&quot; ... std::stringstream Str_Stream; Str_Stream...

66
03.03.2016, 16:05
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.03.2016, 16:05
Помогаю со студенческими работами здесь

как узнать размер std::stringstream
в обьект типа stringstream пишем неизвестное число байт. Как узнать сколько байт записалось в поток?

Ещё раз про поток stringstream!
Всем привет! Вобщем понадобился мне этот поток... Поискал я как его очищать... Нашёл несколько...

Сбрасывается форматирование std::stringstream при очистке потока
Имеем объект класса std::stringstream используемый для форматированного вывода. Перед очередным...

Стандартный поток и STL (std::copy to std::cout)
#include &lt;iostream&gt; #include &lt;sstream&gt; #include &lt;algorithm&gt; #include &lt;functional&gt; #include...

0
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru