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

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

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

Строки - C++

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

Приветствую Вас, братья и сёстры. У меня возникла проблемка с простой задачкой из книжки госпожи Павловской. Вот она: написать программу, которая считывает текст из файла и выводит на экран только предложения, содержащие введённое с клавиатуры слово.
У меня было два варианта решения этой задачи, но после быстрого вымирания моих нервных клеток, первый вариант я отбросил, а вот пример второго:
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
#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);
ничего не меняется...
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.08.2008, 15:08
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Строки (C++):

Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки - C++
Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки. 1. Я дуб дубом,даже...

Добавить строки, начиная со строки К1 и до строки К2, в динамический массив строк - C++
Есть динамический массив строк. Заполняется, т.е. размер его уже известен будет. Но дальше нужно сделать задание: &quot;Добавить строки, начиная...

Удалить строки динамической матрицы, начиная со строки К1 и до строки К2 - C++
Сформировать динамический двумерный массив, заполнить его случайными числами и удалить строки, начиная со строки К1 и до строки К2 вот...

Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести номер позиции первой строки, с которой вторая строка содер-жится в ней - C++
Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести номер позиции первой строки, с которой вторая строка...

Вычислить длину введенной строки и вывести символы строки с четными индексами - C++
Напишите программу, которая требует ввода строки с клавиатуры. Программа вычисляет длину строки и выводит на экран только те символы...

Найти среднее арифметическое каждой строки матрицы и отсортировать строки по возрастанию - C++
Дана квадратная матрица. Найти среднее арифметическое каждой строки и отсортировать строки по возрастанию этих характеристик

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Vourhey
Почетный модератор
6481 / 2256 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
02.08.2008, 18:46 #16
Блин, давай немного сам будешь разбираться, а? Используй fail() у потока.
0
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
02.08.2008, 18:58  [ТС] #17
тоесть если я напишу
fin.getline(line, sizeof(line)) ;
if (fin.fail()) cout << "хрен" << endl;
то если ошибка, то мне хрен выведет?
он его выводит
0
Vourhey
Почетный модератор
6481 / 2256 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
02.08.2008, 19:06 #18
Если выводит, значит ошибка. Теперь проверяй сами биты. Проверь eof, проверь bad.
0
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
02.08.2008, 19:10  [ТС] #19
короче, позиция у меня в конце файла... чтоб эту Павловскую с её задачами...
спасибо за помощь, в сентябре у препода спрошу...
не надо мучаться, я на это дело забил, пойду дальше...
0
Vourhey
Почетный модератор
6481 / 2256 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
02.08.2008, 19:12 #20
Это самое плохое решение Ну да ладно.

Добавлено через 50 секунд
Кинь сюда код итоговый. Где у тя там позиция в конце...
0
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
02.08.2008, 20:08  [ТС] #21
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
#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, но это я для проверки писал
0
Vourhey
Почетный модератор
6481 / 2256 / 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);
Ну вот. Мог же сам разобраться.
0
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))
где он устанавливает указатель?
0
Vourhey
Почетный модератор
6481 / 2256 / 123
Регистрация: 29.07.2006
Сообщений: 12,635
03.08.2008, 00:16 #24
На начало следующей строки.

P. S. работоспособность примеров зависит от компилятора ))
0
yogurt
61 / 61 / 1
Регистрация: 02.08.2008
Сообщений: 106
03.08.2008, 00:20  [ТС] #25
это было второе задание из 20 5-ого семинара, а их будет штук 20, так что айл би бэк
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.08.2008, 00:20
Привет! Вот еще темы с ответами:

Упорядочить символы строки B в алфавитном порядке и удалить латинские буквы из строки A - C++
&quot;Даны строки A и B. Если в A есть латинские буквы, а в B нет повторяющихся символов, то упорядочить символы B в алфавитном порядке и...

Как считать строки из файла, если там больше одной строки? - C++
Как считать строки из файла в массив. Если в файле одна строка, то нет проблем, но если несколько, то при использовании функции fgets ...

Как первые два символа строки переставить в конец этой строки? - C++
Собственно вопрос

Указать номер строки, максимально удаленной от первой строки заданной матрицы - C++
Задание: Расстояние между k-й и 1-й строками квадратной матрицы А опеределяется как r = сумма от j=1 до N от (abs(akj)*abs(a1j)). Указать...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
03.08.2008, 00:20
Ответ Создать тему
Опции темы

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