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

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

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

Скопировать второе слово из каждой строки и вставить их в новый текстовый файл - C++

09.11.2011, 23:16. Просмотров 826. Ответов 15
Метки нет (Все метки)

Добрый вечер, помогите, пожалуйста, в реализации простенькой программы:

На входе .txt файл, в котором некое множество строк, состоящих из 3 "слов", необходимо копировать, например, второе слово из каждой строки и:
1) вставлять их в новый текстовый файл подряд, лишь добавляя * между ними без пробелов и запятых
2) вставлять их в новый текстовый файл каждый раз с новой строки


Голова уже не варит, отчаялась(
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.11.2011, 23:16
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Скопировать второе слово из каждой строки и вставить их в новый текстовый файл (C++):

Скопировать второе слово каждой строки в начало следующей строки - C++
Привет, прошу помощи! Заранее спасибо! Индивидуальное задание: Скопировать второе слово каждой строки в начало следующей строки ...

Скопировать текстовый файл в новый файл, заменив в каждой строке слова «ok» на «*» - C++
Прошу помочь с задачей.Теории не было, сразу практика.Должны своими мозгами , но моих не хватает. Это последняя задача и завтра зачет.=/ ...

Дан текстовый файл, содержащий целые числа. Определить в каждой четной строке максимальное число и записать результаты в новый текстовый файл - C++
Дан текстовый файл, содержащий целые числа. Определить в каждой четной строке максимальное число и записать результаты в новый текстовый...

Дан текстовый файл ( определить слово с наибольшим количеством букв и вставить его на начало и конец строки) - C++
Дан текстовый файл определить слово с наибольшим количеством букв и вставить его на начало и конец строки. Вот мой код #include...

Второе слово второй строки нужно скопировать в первую строку - C++
дано 2 строки, каждые имеют 5 слов с пробелами, нужно обычным способом составить код чтобы 2-ое слово 2-ой строки нужно скопировать в 1-ую...

Получить новый файл, в котором все вхождения первого слова заменены на второе слово - C++
Доброго времени суток, очень прошу помочь! Который день бьюсь над задачей и ничего не выходит. Уже не знаю что и делать (( Дан...

15
Gepar
1177 / 533 / 20
Регистрация: 01.07.2009
Сообщений: 3,517
09.11.2011, 23:17 #2
Ну а как же наработки, если их нет то копайте в эту сторонуhttp://www.cplusplus.com/reference/iostream/fstream/
0
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 00:33  [ТС] #3
У меня проблема в понимании.. Дело в том, что в каждой строке гарантированно находятся три слова. А вот между ними может быть неопределённое количество пробелов...

1)
C++
1
int first = string.indexOf(" ")
- найду индекс 1го пробела
2)
C++
1
2
3
4
5
6
7
8
int i = first;
if(string[i] == " ") i++;
else
{ int end_index = indexOf(i, " ");
string[] word = new char[end_index - i];
for (int j=0; j<end_index-i; j++)
word[j] = string[i+j];
}
Как быть с этими пробелами?
0
Dekio
Фрилансер
Эксперт С++
5837 / 1218 / 214
Регистрация: 23.11.2010
Сообщений: 3,378
Записей в блоге: 1
10.11.2011, 00:35 #4
Whitesmith, find_first_of и find_first_not_of в помощь
0
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 01:03  [ТС] #5
А без них..как-нибудь попроще можно?Т_т
0
Dekio
Фрилансер
Эксперт С++
5837 / 1218 / 214
Регистрация: 23.11.2010
Сообщений: 3,378
Записей в блоге: 1
10.11.2011, 01:08 #6
Whitesmith, strtok к примеру
0
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 03:14  [ТС] #7
Пффф, пытаясь решать, пришла к выводу, что в моём случае достаточно сдвига)

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
#include <stdio.h>
#include <iostream>
#include <fstream>
using namespace std;
 
int main () {
 ifstream ifs ("in.txt");
 string temp;
 
  
 ofstream out("out.txt");       
        
 while (!ifs.eof()) {
    ifs>> temp;
    temp.append("*");
    out<< temp<< endl;
    temp.clear();
    
 
}
 getchar ();
 return 0;
 
}

Добавлено через 1 час 37 минут
Как мне найти в потоке из получаемого большого кол-ва уже единичных подстрок (i=2,i<strLength,i+3)?

И для выполнения задания 1 удаление знаков абзаца(обрыва строки) мне должно помочь? А то так и не поняла как это делать(
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.11.2011, 03:20 #8
Цитата Сообщение от Whitesmith
А вот между ними может быть неопределённое количество пробелов...
они же удаляются по условию
0
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 03:37  [ТС] #9
Должны удаляться, угум

На данный момент этого добилась указанным выше способом:
Скопировать второе слово из каждой строки и вставить их в новый текстовый файл

Пытаюсь разобраться с strtok и сотоварищами, но сон берёт верх
0
Jupiter
Каратель
Эксперт С++
6558 / 3979 / 227
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
10.11.2011, 04:04 #10
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от Whitesmith Посмотреть сообщение
На входе .txt файл, в котором некое множество строк, состоящих из 3 "слов", необходимо копировать, например, второе слово из каждой строки и:
1) вставлять их в новый текстовый файл подряд, лишь добавляя * между ними без пробелов и запятых
2) вставлять их в новый текстовый файл каждый раз с новой строки
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
#include <string>
#include <fstream>
 
int main()
{
    std::ifstream inf("input.txt");
    std::ofstream ofs("output.txt");
    std::string tmp;
    std::size_t pos, counter(0);
 
    while (inf >> tmp && ++counter)
    {
        if (counter % 2 == 0) //каждое второе слово
        {
            while ((pos = tmp.find_first_of(",.!?;:-")) != std::string::npos) //избавимся от знаков препинания если они есть
                tmp.erase(pos, 1);
 
            ofs << tmp << '*';
            // ofs << tmp << std::endl; //для варианта 2) вставлять их в новый текстовый файл каждый раз с новой строки
        }
    }
 
    return 0;
}
1
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.11.2011, 04:32 #11
Цитата Сообщение от Jupiter
Код C++
а как ты выводишь в конце звёздочку ?
а как обрабатывается строка "abc,def,,ghi,jkl" ?

там вообще getline() нужна
0
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 04:44  [ТС] #12
Ооо.. В принципе так и должно было получиться, если бы я работала программистом..
Красиво читается и выглядит!
Только вот что с каунтером? Как-то можно избавиться от If, чтобы находить именно каждый 2-ое слово в подстроке, то есть 2,5,8,11, на сейчас получается так:
Скопировать второе слово из каждой строки и вставить их в новый текстовый файл
(на момент тестирования с данным примером убрала тире из исключений знаков препинания)
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.11.2011, 04:58 #13
Цитата Сообщение от Whitesmith
Ооо.. В принципе так и должно было получиться, если бы я работала программистом..
да, ты права, но ты имеешь в виду стиль оформления кода
0
Jupiter
Каратель
Эксперт С++
6558 / 3979 / 227
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
10.11.2011, 05:33 #14
Цитата Сообщение от Whitesmith Посмотреть сообщение
Только вот что с каунтером? Как-то можно избавиться от If, чтобы находить именно каждый 2-ое слово в подстроке
ну что за беда, а самой подумать не?
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
#include <string>
#include <fstream>
 
int main()
{
    std::ifstream inf("input.txt");
    std::ofstream ofs("output.txt");
    std::string tmp;
    std::size_t pos, counter(0), cur(2);
 
    while (inf >> tmp && ++counter)
    {
        if (counter % cur == 0) 
        {
            cur += 3;
            while ((pos = tmp.find_first_of(",.!?;:-")) != std::string::npos) //избавимся от знаков препинания если они есть
                tmp.erase(pos, 1);
 
            ofs << tmp << '*';
        }
    }
 
    return 0;
}
Добавлено через 1 минуту
Цитата Сообщение от accept Посмотреть сообщение
а как ты выводишь в конце звёздочку ?
а как обрабатывается строка "abc,def,,ghi,jkl" ?
сдесь можно и парсер написать, но это уже заботы ТС
1
Whitesmith
0 / 0 / 0
Регистрация: 09.11.2011
Сообщений: 7
10.11.2011, 06:10  [ТС] #15
Спасибо вам большущее! Дальше программу усложнять буду сама
0
10.11.2011, 06:10
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.11.2011, 06:10
Привет! Вот еще темы с ответами:

Файл: Скопировать текст в другой текстовый файл файл, но чётные строки должны быть с большой буквы... - C++
Создать текстовый файл. Скопировать текст в другой текстовый файл файл, но чётные строки должны быть с большой буквы, а нечетные с...

Замена слов: получить новый файл, в котором все вхождения первого слова заменены на второе слово - C++
Помогите, пожалуйста, с программой. Дан текстовый файл и два слова. Переносов слов нет. Получить новый файл, в котором все...

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

Переформатировать текстовый файл так, чтобы в каждой строчке находилось ровно одно слово - C++
У меня на днях появилась проблема. Проблема называется С++. Эта проблема появляется у меня периодически с сентября месяца, но щас она у...


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

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

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