-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145

Даны два файла. Переписать в третий файл только те слова, которые есть и в первом и во втором файле.

12.02.2013, 20:04. Показов 5042. Ответов 15
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите создать программу: Даны два текстовых файла, содержащих некоторый текст. Переписать в третий файл только те слова, которые есть и в первом и во втором файле.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.02.2013, 20:04
Ответы с готовыми решениями:

Файл: Переписать в третий файл только те слова, которые есть и в первом и во втором исходных файлах
Здравствуйте, вынуждена обратиться за помощью в решении следующей задачи: "Даны два текстовых файла, содержащих некоторый текст. Переписать...

Переписать в третий файл только те строчки, которые есть и в первом, и во втором файлах.
Заданы 2 текстовых файла. Переписать в третий только те строчки, которые есть и в первом, и во втором файлах.

Записать в третий файл только те строки, которые есть и в первом, и во втором файлах
Даны два текстовых файла. Записать в третий только те строки, которые есть и в первом, и во втором файлах

15
4 / 4 / 1
Регистрация: 25.10.2012
Сообщений: 104
12.02.2013, 20:27
frank_lampard, вот я тут набросал по мере своих возможностей на данный момент.

100% есть более изящный и эргономичный вариант!

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
#include <fstream>
#include <iostream>
#include <vector>
#include <string>
 
using namespace std;
 
int main()
{
    string word;
    vector<string> file1;
    vector<string> file2;
    vector<string> file3;
    
    ifstream in1("file1.txt");
    ifstream in2("file2.txt");
    ofstream out("file3.txt");
    
    while(in1 >> word)
    {
         file1.push_back(word);
    }
    
    while(in2 >> word)
    {
        file2.push_back(word);
    }
    
    for(int i = 0; i < file1.size(); i++)
    {
        for(int j = 0; j < file2.size(); j++)
        {
            if(file1[i] == file2[j]) {
                out << i + 1 << ": " << file1[i] << "\n";
            }
        }
    }
}
1
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
12.02.2013, 20:29  [ТС]
denvasden
Спасибо. А можно узнать где берется третий файл? Только начал работать с файлами.
0
4 / 4 / 1
Регистрация: 25.10.2012
Сообщений: 104
12.02.2013, 20:34
frank_lampard, файл создавал вручную. если нужно его создавать по ходу программы есть функция
fopen()
она создаст файл автоматически если его не существует.

вот тут почитать можно:http://www.cplusplus.com/reference/cstdio/fopen/
1
 Аватар для Quadro9
32 / 32 / 1
Регистрация: 23.07.2009
Сообщений: 170
15.02.2013, 00:35
переделал твой код с использованием сета, правда я его не проверял, так как под рукой нет компилятора

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 <fstream>
#include <iostream>
#include <set>
#include <string>
 
using namespace std;
 
int main()
{
    string word;
    set<string> myset;
    set<string>::iterator it;
 
    ifstream in1("file1.txt");
    ifstream in2("file2.txt");
    ofstream out("file3.txt");
    
    while(in1 >> word)
    {
         myset.insert(word);
    }
    
    while(in2 >> word)
    {
        myset.insert(word);
    }
    
    for(it = myset.begin(); it != myset.end(); it++)
    {
        out  << *it << "\n";
    }
}
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 13:50  [ТС]
А можете дать листинг с использованием функции fopen()?
0
 Аватар для DiffEreD
1458 / 795 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
08.03.2013, 15:10
С векторами:
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
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <iterator>
#include <fstream>
 
int main(int argc, char** argv) 
{
    setlocale (0, "Russian");
    
    std::ifstream in1("D:/file1.txt");
    std::ifstream in2("D:/file2.txt");
    if (in1.is_open() && in2.is_open())
    {
        std::ofstream out("D:/file3.txt");
        std::vector<std::string> v{std::istream_iterator<std::string>(in1), std::istream_iterator<std::string>()};
        v.assign(std::istream_iterator<std::string>(in2), std::istream_iterator<std::string>());
        std::sort(v.begin(), v.end());
        std::unique_copy(v.begin(), v.end(), std::ostream_iterator<std::string>(out, " "));
    }
    else
        std::cout<<"Ошибка открытия файла\n";
    
    return 0;
}
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 15:20  [ТС]
yuron_477, можете объяснить что предоставляет библиотека "vector" и "iterator"? Я такого не знаю. Мне желательно бы чтобы вы показали программу в "stdio.h" с операторами fscanf и fprintf с присутствием fopen(). Был бы признателен.
0
 Аватар для DiffEreD
1458 / 795 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
08.03.2013, 15:32
Цитата Сообщение от frank_lampard Посмотреть сообщение
Мне желательно бы чтобы вы показали программу в "stdio.h" с операторами fscanf и fprintf с присутствием fopen()
Сожалею, но с этим синтаксисом я не очень знаком.
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 16:09  [ТС]
yuron_477, а можете ваши операторы объяснить?
0
 Аватар для DiffEreD
1458 / 795 / 257
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
08.03.2013, 16:30
frank_lampard, вам надо STL учить, толку от моих комментариев вам не будет мало, надо понимать работу стандартных алгоритмов и итераторов.
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
int main(int argc, char** argv) 
{
    setlocale (0, "Russian");  // для русификации текста
    
    std::ifstream in1("D:/file1.txt");
    std::ifstream in2("D:/file2.txt");
    if (in1.is_open() && in2.is_open())  // если файлы открыть не удалось, то завершаем программу 
    {
        std::ofstream out("D:/file3.txt");
        //инициализируем вектор интервалом итераторов std::istream_iterator которые считывают слово за словом
        //пока не дойдут до конца первого файла ({}- это списковая инициаоизация, С++11)
        std::vector<std::string> v{std::istream_iterator<std::string>(in1), std::istream_iterator<std::string>()};
        //добавляем в наш контейнер новый интервал значений из второго файла
        v.assign(std::istream_iterator<std::string>(in2), std::istream_iterator<std::string>());
        // сортируем контейнер стандартным алгоритмом для правильной подальшей выборки из него
        //уникальных слов
        std::sort(v.begin(), v.end());  
        //этот алгоритм пишет в выходной файл только уникальные не повторяющиеся слова с помощью std::ostream_iterator
        //правильно работает только с отсортированными контейнерами
        std::unique_copy(v.begin(), v.end(), std::ostream_iterator<std::string>(out, " "));
    }
    else
        std::cout<<"Ошибка открытия файла\n";
    
    return 0;
}
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 17:37  [ТС]
yuron_477, всё равно спасибо!
0
0 / 0 / 0
Регистрация: 08.03.2013
Сообщений: 12
08.03.2013, 18:00
Цитата Сообщение от frank_lampard Посмотреть сообщение
yuron_477, можете объяснить что предоставляет библиотека "vector" и "iterator"? Я такого не знаю. Мне желательно бы чтобы вы показали программу в "stdio.h" с операторами fscanf и fprintf с присутствием fopen(). Был бы признателен.
а зачем вам знакомиться с fscanf и fprintf ?

библиотека fstream лучше(экономичней, удобней) реализована.
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 18:50  [ТС]
andrew_vorobey, начал с этого. Можете помочь с fscanf и fprintf?
0
0 / 0 / 0
Регистрация: 07.03.2013
Сообщений: 5
08.03.2013, 18:59
но без STL без ограничения не представляю как записать ((

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
#include <stdio.h>
#include <string.h>
 
int main()
{
    FILE *in;
    FILE *in1;
    FILE *out;
    char str[10];
    char str1[10];
 
    if(! (in = fopen("file1.txt", "r") ) )
        return 0;
 
    if(! (in1 = fopen("file2.txt", "r") ) )
        return 0;
 
    out = fopen("out.txt", "w");
    
    while(fgets(str, 10, in))
    {
        while(fgets(str1, 10, in1))
        {
            if(! strcmp(str, str1) )
                fputs(str, out);
        }
        fseek(in1, 0, 0);
    }
 
    fclose(in);
    fclose(in1);
    fclose(out);
 
    return 0;
}
0
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
08.03.2013, 23:06  [ТС]
_XDD_, спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.03.2013, 23:06
Помогаю со студенческими работами здесь

Записать в третий файл только те строки, которые есть и в первом, и во втором файлах
Program lab8; uses crt; var f,f1,f2:text; s,s1:String; begin Assign(f,'D:\222.txt'); reset(f); ...

Даны два слова, определить символы которые есть в первом слове и отсутствуют во втором
Даны два слова, определить символы которые есть в первом слове и отсутствуют во втором.

Создать два бинарных файла, содержащих числовую информацию. В результате преобразований в первом файле должны остаться только четные, а во втором
Создать два бинарных файла, содержащих числовую информацию. В результате преобразований в первом файле должны остаться только четные, а во...

Создать третий одномерный массив x состоящий из чисел, которые есть и в первом и во втором массиве
Даны два одномерных массива a и b.Числа вводятся с клавиатуры.Создать третий одномерный массив x состоящий из чисел,которые есть и в первом...

Создать третий стек из тех символов первого стека, которые есть и в первом и во втором стеке
Из двух заданных стеков, хранящих символы, создать новый стек из тех символов первого стека, которые есть и в первом и во втором стеке ...


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

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

Новые блоги и статьи
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
Взаимодействие Python с REST API
py-thonny 27.03.2025
REST API - это архитектурный стиль взаимодействия компонентов распределённого приложения в сети. Python располагает функциональным набором инструментов для работы с REST API и основная библиотека для. . .
sshd restrictions, ssh access limitations
jigi33 26.03.2025
sshd restrictions | ssh access limitations рестрикции доступа на сервер sshd статья: https:/ / www. golinuxcloud. com/ restrict-allow-ssh-certain-users-groups-rhel
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru