Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
#1

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

23.01.2014, 19:21. Просмотров 1095. Ответов 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
Здравствуйте! Я подобрал для вас темы с ответами на вопрос std::string, потоки (C++):

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

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

запрошено преобразование от ‘const std::string*’ к нескалярному типу ‘std::string’ - C++
private: std::string firstName; }; std::string ClientData::getFirstName() const{ return firstName; } Дает в итоге...

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

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

Операция std::cout для Объекта типа std::string - C++
Кто детально объяснит почему не выводит ? Дает вот так &quot;Отсутствует оператор &quot;&lt;&lt;&quot;, соответствующий этим операндам&quot; void...

31
alsav22
5428 / 4823 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.02.2014, 21:00 #16
Цитата Сообщение от qwerty778 Посмотреть сообщение
это разные топики) Тут же у меня другая проблема.
Раз другая проблема, то зачем к моему коду отправляете, который под другую проблему был выложен?
Цитата Сообщение от qwerty778 Посмотреть сообщение
код Ваш, в этом топике выше
Код покажите. Я как должен видеть проблему, если кода не вижу? В моём коде, нет никаких
Цитата Сообщение от qwerty778 Посмотреть сообщение
buf1==buf2
0
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
02.02.2014, 14:17  [ТС] #17
alsav22, сорри, вот фрагмент моего кода с вашим:
Кликните здесь для просмотра всего текста
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
while (getline(dic, buf2)) { //wrong words to file
            if (buf2 < buf1)
                continue;
            ////////////////////////////////////////////////////////////
            else if (buf2 == buf1) { //remove cursor to line up
                streamoff pos;
                dic.seekg(-3, ios::cur);
                while (dic.peek() != '\n')
                {
                    dic.seekg(-1, ios::cur);
                    if ((pos = dic.tellg()) == 0) {
                        break;
                    }
                }
 
                if (pos != 0)
                    dic.seekg(2, ios::cur);
                break;
            }
            ///////////////////////////
            else {
                def << buffer << endl;
                break;
            }
        }
0
alsav22
5428 / 4823 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
02.02.2014, 22:11 #18
Мой код делает это:
Цитата Сообщение от qwerty778 Посмотреть сообщение
Т.е. мне нужно указатель преместить на строку выше.
Теперь подумайте, что будет происходить в вашем коде (17 пост). Считали строку, вернулись к началу её же, опять считали и т.д. Должно быть ещё одно чтение, чтобы читались следующие строки. Как у вас это должно быть сделано, без понятия, но вот пример кода на эту тему, и результат работы:
в файле:
aaa aaa
bbb bbb
ccc ccc
ddd ddd
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
void f(istream& dic) // перемещает курсор на строку выше
{
    streamoff pos;
    dic.seekg(-3, ios::cur);
    while (dic.peek() != '\n')
    {
        dic.seekg(-1, ios::cur);
        if ((pos = dic.tellg()) == 0)
                        break;
    }
    if (pos != 0)
        dic.seekg(2, ios::cur);
}
 
int main()
{
    ifstream dic("1.txt");
    if (dic)
    {
        string buf1 = "\0";
        string buf2;
        while(getline(dic, buf2)) 
        {
            cout << buf2 << endl;
        
            while(getline(dic, buf2)) 
            {
                cout << buf2 << endl;
                if (buf2 < buf1) 
                {
                    f(dic);
                    continue;
                }
                else if (buf2 == buf1)
                {
                    f(dic);
                    break;
                }
                else 
                {
                    f(dic);
                    break;
                }
            }
        }
        dic.close();
 
    }
    else
        cout << "Error!" << endl;
 
    system("pause");
    return 0;
}
0
Миниатюры
std::string, потоки  
alsav22
5428 / 4823 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
02.02.2014, 23:50 #19
Вот вариант, чтобы повторно читалась и первая строка (даже если в ней одна буква):
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
void f(istream& dic) // перемещает курсор на строку выше
{
    streamoff pos;
    dic.seekg(-3, ios::cur);
    dic.clear();
    if ((pos = dic.tellg()) == -1)
    {
        dic.clear();
        dic.seekg(0);
        pos = dic.tellg();
        return;
    }
    while (dic.peek() != '\n')
    {
        dic.seekg(-1, ios::cur);
        pos = dic.tellg();
        if (pos == -1)
        {
            dic.clear();
            dic.seekg(0);
            pos = dic.tellg();
            break;
        }
    }
    if (pos != 0)
        dic.seekg(2, ios::cur);
}
 
int main()
{
    ifstream dic("1.txt");
    if (dic)
    {
        string buf1 = "\0";
        string buf2;
        bool flag = false;
        while(getline(dic, buf2)) 
        {
            cout << buf2 << endl;
            if (buf2 < buf1) 
            {
                f(dic);
                   
            }
            else if (buf2 == buf1)
            {
                f(dic);
            }
            else 
            {
                f(dic);
            }
            if (getline(dic, buf2))
                cout << buf2 << endl;
        }
        dic.close();
    }
    else
        cout << "Error!" << endl;
 
    system("pause");
    return 0;
}

В общем, код нужно подгонять под конкретную задачу.
0
Миниатюры
std::string, потоки  
qwerty778
1 / 1 / 0
Регистрация: 09.01.2014
Сообщений: 56
03.02.2014, 02:34  [ТС] #20
alsav22, хорошо, тогда как понять, что нет строки выше, и указатель переместить нельзя?
0
alsav22
5428 / 4823 / 442
Регистрация: 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
5428 / 4823 / 442
Регистрация: 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
5428 / 4823 / 442
Регистрация: 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
5428 / 4823 / 442
Регистрация: 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
5428 / 4823 / 442
Регистрация: 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
08.02.2014, 14:52
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.02.2014, 14:52
Привет! Вот еще темы с ответами:

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

Почему std::string_view МЕДЛЕННЕЕ, чем std::string? - C++
Всем привет! Нужно найти количество уникальных строк в больших текстовых файлах (размером до нескольких гигабайт). Почему в...

Как правильно перевести std::wstring в std::string ? - C++
Собственно как? :)

Как привести std::wstring к std::string? - C++
Как привести std::wstring к std::string?


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

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

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