Форум программистов, компьютерный форум CyberForum.ru

std::string, потоки - C++

Восстановить пароль Регистрация
 
 
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
23.01.2014, 19:21     std::string, потоки #1
Доброго времени суток! Использую такую конструкцию:
Кликните здесь для просмотра всего текста
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 считывалась бы не новая строка, а использовалась старая.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
03.02.2014, 03:32     std::string, потоки #21
Цитата Сообщение от qwerty778 Посмотреть сообщение
тогда как понять, что нет строки выше, и указатель переместить нельзя?
Это кто говорит?

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

Добавлено через 14 минут
Для чего это двойное чтение нужно?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
03.02.2014, 20:34  [ТС]     std::string, потоки #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;
            }
        }
    }
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
04.02.2014, 02:47     std::string, потоки #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;
}
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
05.02.2014, 15:51  [ТС]     std::string, потоки #24
alsav22, тут понимаете в чём дело... Файл srt.txt уже отсортирован, ибо словарь гигантский, и проверку желательно осуществить за один проход.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
06.02.2014, 00:14     std::string, потоки #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;
}
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
06.02.2014, 19:25  [ТС]     std::string, потоки #26
alsav22, слова в обоих файлах отсортированы. Проверка в один проход, как словаря, так и файла пользователя (это даже не файл пользователя, это файл, где все слова из его исходного файла отсортированы). В файл должны записаться слова, которых нет в словаре.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
07.02.2014, 07:48     std::string, потоки #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;
}
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
07.02.2014, 22:10  [ТС]     std::string, потоки #28
alsav22, тут смотрите какой баг: если слова в отсортированном файле повторяются, и их, например, 3, то в файл запишется 2, так как будет считана следующая строка из словаря, и, соответственно, она будет больше строки из отсортированного файла. В общем-то, с этим я и боролся, для этого и была создана тема.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
07.02.2014, 23:48     std::string, потоки #29
По-моему, не с тем боретесь. Такие вещи нужно устранять раньше, на этапе сортировки.
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
08.02.2014, 14:52  [ТС]     std::string, потоки #30
alsav22, дело в том, что в отсортированный файл пишутся не только слова, но и кое-какие данные, а именно: номер строки, положение первого символа слова в строке, длина слова. Поэтому это осознанно не устранено на этапе сортировки.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
09.02.2014, 03:42     std::string, потоки #31
Цитата Сообщение от qwerty778 Посмотреть сообщение
Поэтому это осознанно не устранено на этапе сортировки.
Ну, если осознанно, то продолжайте мучиться с фильтрацией на лету. Удачи!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.02.2014, 22:21     std::string, потоки
Еще ссылки по теме:

C++ Error C2664: std::vector<_Ty>::push: невозможно преобразовать параметр 1 из 'double' в 'const std::string &'
C++ Std::string and std::wstring convert
Потоки и прямая запись в заданый std::string C++

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

Или воспользуйтесь поиском по форуму:
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
09.02.2014, 22:21  [ТС]     std::string, потоки #32
alsav22, спасибо, Ваше пожелание удачи было мне просто необходимо.
Yandex
Объявления
09.02.2014, 22:21     std::string, потоки
Ответ Создать тему
Опции темы

Текущее время: 05:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru