Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
1

std::string, потоки

23.01.2014, 19:21. Просмотров 1171. Ответов 31
Метки нет (Все метки)

Доброго времени суток! Использую такую конструкцию:
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
while(...) {
        while(getline(dic, buf2)) {
                if (buf2 < buf1) continue;
            else if (buf2 == buf1) break;
            else {
                    def << buffer << endl;
            break;
    }
}

После выполнения else if происходит возврат во внешний while, и хотелось бы, чтобы по достижении внутреннего while считывалась бы не новая строка, а использовалась старая.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.01.2014, 19:21
Ответы с готовыми решениями:

ошибка error: cannot convert 'std::string {aka std::basic_string<char>}' to 'std::string* {aka std::basic_stri
на вод поступают 2 строки типа string. определить количество вхождений строки 2...

Потоки и прямая запись в заданый std::string
Есть ли в бусте/последних стандартах C++ поток, пишущий/читающий напрямую в/из...

Запрошено преобразование от ‘const std::string*’ к нескалярному типу ‘std::string’
private: std::string firstName; }; std::string...

На основе исходного std::vector<std::string> содержащего числа, создать std::vector<int> с этими же числами
подскажите есть вот такая задача. Есть список . Создать второй список, в...

Реализация класса MyString. Стандартная библиотека, std::string, std::vector
как добавить реализацию конкатенации строк через перегрузку оператора &quot;+=&quot; в...

31
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
03.02.2014, 03:32 21
Цитата Сообщение от qwerty778 Посмотреть сообщение
тогда как понять, что нет строки выше, и указатель переместить нельзя?
Это кто говорит?

Добавлено через 1 минуту
Алгоритм работы какой должен быть?

Добавлено через 14 минут
Для чего это двойное чтение нужно?
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
03.02.2014, 20:34  [ТС] 22
alsav22, В общем, идёт сравнение строк из словаря и из файла пользователя. Если они равны, то надо взять следующую строку из файла пользователя и эту же строку из словаря.
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
while (getline(srt, buffer)) { //search for wrong words
        buf1.clear();
        for (int i = 0; i < buffer.length(); i++) { //only words
            if (buffer[i] == ' ')
                break;
            else
                buf1.push_back(buffer[i]);
        }
        while (getline(dic, buf2)) { //wrong words to file
            if (buf2 < buf1)
                continue;
            ////////////////////////////////////////////////////////////
            else if (buf2 == buf1) { //remove cursor to line up
                   Ваш код
                        }
            ///////////////////////////
            else {
                def << buffer << endl;
                break;
            }
        }
    }
0
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
04.02.2014, 02:47 23
Тут смысла нет передвигать курсор по строкам. Если задача в том, чтобы записать, в выходной файл, слова из файла пользователя, которых нет в словаре:
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
#include <cstdlib>
using namespace std;
 
int main()
{
   // Записать, в выходной файл, слова из файла пользователя, которых нет в словаре.
    
   string buf1;
   string buf2;
   ifstream srt("srt.txt"); // файл пользователя
   ifstream dic("dic.txt"); // файл словаря
   ofstream def("def.txt"); // выходной файл
   if (srt && dic)
   {
        bool exist = false; // есть ли слово
        while (srt >> buf1) //слово из файла пользователя
        { 
            while (dic >> buf2) // перебор словаря
            { 
                if (buf2 == buf1) // если такое слово есть в словаре
                {
                    exist = true;
                    break;
                }
            }
            if (exist) // если такое слово есть в в словаре
            {
                exist = false; 
                dic.seekg(0);  // чтение словаря с начала
            }
            else  // словаре пройден, слово не найдено.
            {
                def << buf1 << endl; // записываем такое слово в выходной файл
                dic.clear();
                dic.seekg(0); // чтение словаря с начала
            }
        }
    }
    else 
       cout << "Error!" << endl;
    
    system("pause");
    return 0;
}
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
05.02.2014, 15:51  [ТС] 24
alsav22, тут понимаете в чём дело... Файл srt.txt уже отсортирован, ибо словарь гигантский, и проверку желательно осуществить за один проход.
0
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
06.02.2014, 00:14 25
Цитата Сообщение от qwerty778 Посмотреть сообщение
и проверку желательно осуществить за один проход.
За один проход словаря и файла пользователя? Или только словаря? Если только словаря, то измените в моём коде первое чтение на чтение слова из словаря (а не из файла пользователя). Это будет один проход словаря, но не один - файла пользователя. В выходной файл будут записаны слова, которые есть в словаре, но нет в файле пользователя. Или что должно быть записано в выходной файл?
Кликните здесь для просмотра всего текста
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
#include <string>
#include <cstdlib>
using namespace std;
 
int main()
{
   // Записать, в выходной файл, слова из словаря, которых нет в файле пользователя.
    
   string buf1;
   string buf2;
   ifstream srt("srt.txt"); // файл пользователя
   ifstream dic("dic.txt"); // файл словаря
   ofstream def("def.txt"); // выходной файл
   if (srt && dic)
   {
        bool exist = false; // есть ли слово
        while (dic >> buf2) //слово из словаря
        { 
            while (srt >> buf1) // перебор файла пользователя
            { 
                if (buf2 == buf1) // если такое слово есть в файле пользователя
                {
                    exist = true;
                    break;
                }
            }
            if (exist) // если такое слово есть в файле пользователя
            {
                exist = false; 
                srt.seekg(0);  // чтение файла пользователя с начала
            }
            else  // файл пользователя пройден, слово не найдено.
            {
                def << buf2 << endl; // записываем такое слово в выходной файл
                srt.clear();
                srt.seekg(0); // чтение файла пользователя с начала
            }
        }
    }
    else 
       cout << "Error!" << endl;
    
    system("pause");
    return 0;
}
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
06.02.2014, 19:25  [ТС] 26
alsav22, слова в обоих файлах отсортированы. Проверка в один проход, как словаря, так и файла пользователя (это даже не файл пользователя, это файл, где все слова из его исходного файла отсортированы). В файл должны записаться слова, которых нет в словаре.
0
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
07.02.2014, 07:48 27
Цитата Сообщение от qwerty778 Посмотреть сообщение
слова в обоих файлах отсортированы. Проверка в один проход, как словаря, так и файла пользователя. В файл должны записаться слова, которых нет в словаре.
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
#include <cstdlib>
using namespace std;
 
int main()
{
   // Записать, в выходной файл, слова из файла пользователя, которых нет в словаре.
   // Cлова в обоих файлах отсортированы.
    
   string buf1;
   string buf2;
   ifstream srt("srt.txt"); // файл пользователя
   ifstream dic("dic.txt"); // файл словаря
   ofstream def("def.txt"); // выходной файл
   if (srt && dic)
   {
        while (dic >> buf2) //слово из словаря
        { 
            while (srt >> buf1) // слово из файла пользователя
            { 
                if (buf1 < buf2) // если слово из словаря больше слова из файла пользователя
                {
                    def << buf1 << endl; // записываем такое слово из файла пользователя в выходной файл
                }
                else if (buf1 > buf2) // если слово из словаря меньше слова из файла пользователя
                {
                     while (dic >> buf2) // перебор словаря, до слова больше или равного слову из файла пользователя
                     {
                         if (buf1 < buf2) // если слово из словаря больше слова из файла пользователя
                         {
                            def << buf1 << endl; // записываем такое слово из файла пользователя в выходной файл
                            break; // переход к чтению следующего слова из словаря
                         }
                         if (buf1 == buf2) // если слово из словаря равно слову из файла пользователяпереход, 
                                           // переход к чтению следующего слова из словаря
                             break;
                     }
                     if (buf1 < buf2 || buf1 == buf2 || !dic) // переход к чтению следующего слова из словаря
                         break;
                }
                else 
                    break; // если слово из словаря рано слову из файла пользователя, 
                           // чтение следующего слова из словаря
            }
         }
         
         if (srt) // если слов в файле пользователя больше, чем в словаре, 
                  // или оставшиеся слова больше пследнего слова в словаре
         {
             if (buf1 > buf2)
                def << buf1 << endl;
             while (srt >> buf1)
             {
                 if (buf1 != buf2)
                    def << buf1 << endl; // записываем все оставшиеся слова из файла пользователя,
                                         // не равные последнему считанному из словаря, в выходной файл
             }
         }
    }
    else 
       cout << "Error!" << endl;
    
    system("pause");
    return 0;
}
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
07.02.2014, 22:10  [ТС] 28
alsav22, тут смотрите какой баг: если слова в отсортированном файле повторяются, и их, например, 3, то в файл запишется 2, так как будет считана следующая строка из словаря, и, соответственно, она будет больше строки из отсортированного файла. В общем-то, с этим я и боролся, для этого и была создана тема.
0
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
07.02.2014, 23:48 29
По-моему, не с тем боретесь. Такие вещи нужно устранять раньше, на этапе сортировки.
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
08.02.2014, 14:52  [ТС] 30
alsav22, дело в том, что в отсортированный файл пишутся не только слова, но и кое-какие данные, а именно: номер строки, положение первого символа слова в строке, длина слова. Поэтому это осознанно не устранено на этапе сортировки.
0
alsav22
5442 / 4837 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
09.02.2014, 03:42 31
Цитата Сообщение от qwerty778 Посмотреть сообщение
Поэтому это осознанно не устранено на этапе сортировки.
Ну, если осознанно, то продолжайте мучиться с фильтрацией на лету. Удачи!
1
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
09.02.2014, 22:21  [ТС] 32
alsav22, спасибо, Ваше пожелание удачи было мне просто необходимо.
0
09.02.2014, 22:21
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.02.2014, 22:21

Операция std::cout для Объекта типа std::string
Кто детально объяснит почему не выводит ? Дает вот так &quot;Отсутствует оператор...

Передача функции указатель на элемент std::vector<std::string>
Доброй ночи тем, кому не спится (или живет в другом часовом поясе:p)! Есть...

No match for 'operator<' (operand types are 'std::__cxx11::string {aka std::__c
Имеем следующий код: #include &lt;iostream&gt; #include &lt;string&gt; #include...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru