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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 25, средняя оценка - 4.68
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
#1

Строки - C++

02.08.2008, 15:08. Просмотров 3050. Ответов 24
Метки нет (Все метки)

Приветствую Вас, братья и сёстры. У меня возникла проблемка с простой задачкой из книжки госпожи Павловской. Вот она: написать программу, которая считывает текст из файла и выводит на экран только предложения, содержащие введённое с клавиатуры слово.
У меня было два варианта решения этой задачи, но после быстрого вымирания моих нервных клеток, первый вариант я отбросил, а вот пример второго:
Код
#include <windows.h>
#include <iostream.h>
#include <fstream.h>
#include <stdio.h>
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);

    ifstream fin("Путь к файлу\\Text.txt", ios::in | ios::nocreate);
    if (!fin) {
        cout<<"Ошибка открытия файла."<<endl;
        cin.get();
        return 1;
    }

    fin.seekg(0, ios::end);
    long len=fin.tellg();
    char *buf=new char [len+1];
    char *fub=new char [len+1];
    fin.seekg(0, ios::beg);
    fin.read(buf, len);
    buf[len]='\0';
    char word[20], line[100];
    cout<<"Введите слово: "; cin>>word; cout<<endl;
    long pos;
    while (fin.getline(line, 100)) {
        if (strstr(line,word)) {
            int i, pr_n;
            pos=fin.tellg();
            for (i=pos; i>0; i--) {
                if (buf[i]=='.' || buf[i]=='!' || buf[i]=='?') break;
                pr_n=i;
            }
            for (i=pr_n; i<=pos; i++) cout<<fub[i];
            for (i=pos+1; i<len; i++) {
                cout<<buf[i];
                if (buf[i]=='.' || buf[i]=='!' || buf[i]=='?') break;
            }
            cout<<endl;
        }
    }
    cin.get();
    cin.get();
    return 0;
}
В общем я только начал с этой бредятиной (языком), так что некоторые штучки-дручки мог употребить не правильно. Зарание спасибо за помощь. Если кто поможет и даже код правильный подкинет, то прошу разъяснить там всё, а то слепо не хочется идти дальше...

Добавлено через 1 час 10 минут
я нашёл, где может быть глюк (у меня):
fin.read(buf, len);
наверно после этого указатель становится в самом конце файла, но даже если после этой строки я напишу
fin.seekg(0, ios::beg);
ничего не меняется...
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
02.08.2008, 20:08  [ТС]     Строки #21
Код
#include <windows.h>
#include <iostream.h>
#include <fstream.h>
#include <stdio.h>
int main()
{
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);

    ifstream fin("Путь\\Text.txt", ios::in | ios::nocreate);
    if (!fin) {
        cout<<"Ошибка открытия файла."<<endl;
        cin.get();
        return 1;
    }

    fin.seekg(0, ios::end);
    long len=fin.tellg();
    char *buf=new char [len+1];
    fin.seekg(0, ios::beg);
    fin.read(buf, len);
    fin.seekg(0, ios::beg);
    buf[len]='\0';
    const int leng=100;
    char line[leng];
    long i;
    while (fin.getline(line, leng)) {
        cout<<line<<endl;
    }
    cin.get();
    return 0;
}
тут не используется buf, но это я для проверки писал
Vourhey
Почетный модератор
6474 / 2249 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
02.08.2008, 21:44     Строки #22
Уф. Вообщем я подебажил немного эту прогу.
Когда ты вызваешь read он читает и доходит до конца. Таким образом мы получаем установленный бит eof. Отсюда, мы получаем true на fail().
В либах С++ при вызове seekg проверяется fail(). И если она возвращает true, то сбрасываются все флаги ошибок через вызов clear и возвращается в главную прогу. Если вызвать сторой раз seekg, то fail() вернет false (мы же clear() вызвали прошлый раз.) и пойдет процесс смены позиции, поэтому второй вызов сработает.
Итак, несколько вариантов:
1) два раза вызвать seekg:
Код
fin.seekg(0, ios::beg);
fin.seekg(0, ios::beg);
первый снимет флаги, второй изменит позицию.
2) вручную вызвать снятие флагов:
Код
if (fin.fail())
{
    fin.clear();
}
fin.seekg(0, ios::beg);
3) А взаправду лучше так:
Код
if (fin.eof())
{
   fin.clear();
}
fin.seekg(0, ios::beg);
Ну вот. Мог же сам разобраться.
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
03.08.2008, 00:10  [ТС]     Строки #23
Сам бы я на врядли смог, ибо про clear я мало что знаю и даже сейчас ничего толком не смог найти. Схожу в книжный и куплю справочник, где будут расписаны функции, классы и тому подобное, ибо в моей книженции только то...что почти и не надо, как оказалось.
Гм....аллилуя, брат мой, СЛАВЯНИН, ЗЕМЛЯНИН, такой же сын адама и евы. 3 способ работает (1-ый нет, второй не смотрел). кикин моо факин эсс, как говорит мой знакомый. Спасибо тебе огромное. Пфф, если бы я пил, то пощёл бы нажрался, ибо меня это уже начало доставать...

Добавлено через 6 минут
и тогда ещё вопрос:
после этого
while (fin.getline(line, 10000)) {
if (strstr(line,word))
где он устанавливает указатель?
Vourhey
Почетный модератор
6474 / 2249 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
03.08.2008, 00:16     Строки #24
На начало следующей строки.

P. S. работоспособность примеров зависит от компилятора ))
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.08.2008, 00:20     Строки
Еще ссылки по теме:

Строки. Удалить из строки S1 последнюю подстроку, совпадающую с S2 C++
C++ Ввести 2 строки и вывести на экран "Можно" если из 1 строки можно составить 2 строку
C++ String-строки. C-строки. Лексемы
Разбиение строки на 2 строки C++
C++ Поменять 2 слово первой строки на 3 слово второй строки

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

Или воспользуйтесь поиском по форуму:
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
03.08.2008, 00:20  [ТС]     Строки #25
это было второе задание из 20 5-ого семинара, а их будет штук 20, так что айл би бэк
Yandex
Объявления
03.08.2008, 00:20     Строки
Ответ Создать тему
Опции темы

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