Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 10.12.2018
Сообщений: 25

Считывание строк из файла в массивы и их сортировка слиянием

28.11.2019, 19:27. Показов 1674. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть файл AB.txt, в котором заданы две отсортированные строки по пять чисел на каждой, считать их в два массива и слить их в один отсортированный(сливать перед сортировкой нельзя) и записать рез. массив в С.txt. Вылезают ошибки с преобразованием строки в массив с чилами.
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include "pch.h"
#include <iostream>
#include <fstream>
#include <string>
#include <sstream>
using namespace std;
 
 
 
 
int main(){
    {
        setlocale(LC_ALL, "RUS");
 
        ifstream fin; //объект считывания информации файла
        fin.open("AB.txt"); //открываем файл
 
        //Если файл не получилось открыть
        if (fin.is_open()) {
            const int N = 5;
            const int M = 5;
 
            //Читаем весь файл и записываем информацию в массив строк
            string A1, B1;
 
            getline(fin, A1);
            getline(fin, B1);//читаем файл, пока в нем есть информация
 
            fin.close(); //зыкрываем файл
            int A[N];
            int B[M];
            stringstream ss(A1); {//перобразование строки A1 в массив 
            for (;;)
            {
                
                ss >> A[N];
                if (!ss)
                {
                    break;
                }
                
            }
            return 0;
            }
            
            stringstream ss(B1); {//перобразование строки B1 в массив 
                for (;;)
                {
                    
                    ss >> B[M];
                    if (!ss)
                    {
                        break;
                    }
 
                }
                return 0;
            }
            int* C = new int[N + M];
            int i=0;
            int j=0;
    for (int k = 0; k < 10; k++) {
        if (A[i] < B[j] && i != N) {
                    C[k] = A[i++];
                }
                else if (j != M) {
                    C[k] = B[j++];
                }
                else if (C[k] = B[j]) {
                    j++; i++;
                }
            }
 
            for (int k = 0; k++; k < N+M) {
                cout << C[k] << endl;
            }
            ofstream fin;
            fin.open("С.txt",ofstream::app);
            ofstream ofs;
            ofs.open("С.txt", ofstream::out | ofstream::trunc);
            ofs.close();
            fin << C;
            fin.close();
            delete[] C;
 
        }
        
 
        else {
            cout << "Ошибка! Файл не открыт" << endl;
        }
 
        return 0;
        }
    }
Ошибки
Кликните здесь для просмотра всего текста


Ошибка C2374 ss: переопределение; множественная инициализация 48

Ошибка C2088 >>: недопустимо для class 52

Ошибка C2088 !: недопустимо для class 53

Предупреждение C4552 "<": результат выражения не используется 76

0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.11.2019, 19:27
Ответы с готовыми решениями:

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

Считывание строк файла в массивы указателей
Есть небольшая программка, которая должна считывать построчно файл 1te.txt и записывать каждую его строку в указатель, указывающий(массив...

Считывание строк из файла и их сортировка
дана задача:Описать процедуру sortStrings(S0, S1), считывающую все строки из файла с именем S0 и записывающую эти строки в файл S1. Строки...

4
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
28.11.2019, 20: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
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
70
71
72
73
74
75
76
#include <iostream>
#include <fstream>
#include <string>
#include <sstream>
using namespace std;
 
 
 
 
int main(){
    {
        setlocale(LC_ALL, "RUS");
 
        ifstream fin; //объект считывания информации файла
        fin.open("AB.txt"); //открываем файл
 
        //Если файл не получилось открыть
        if (fin.is_open()) {
            const int N = 5;
            const int M = 5;
 
            //Читаем весь файл и записываем информацию в массив строк
            string A1, B1;
 
            getline(fin, A1);
            getline(fin, B1);//читаем файл, пока в нем есть информация
 
            fin.close(); //зыкрываем файл
            int A[N];
            int B[M];
            {
            stringstream ss(A1); 
            for  (int i=0; i<N && ss >> A[i]; ++i)
                        { }
            }
            
            {
            stringstream ss(B1); 
            for  (int i=0; i<N && ss >> B[i]; ++i)
                        { }
            }
            int* C = new int[N + M];
            int i=0;
            int j=0;
            for (int k = 0; k < N+M; k++) {
                 if ( i != N && A[i] < B[j]) {
                    C[k] = A[i++];
                }
                else if (j != M) {
                    C[k] = B[j++];
                }
            }
 
            for (int k = 0; k < N+M; k++) {
                cout << C[k] << endl;
            }
            ofstream fin;
            fin.open("С.txt",ofstream::app);
            ofstream ofs;
            ofs.open("С.txt", ofstream::out | ofstream::trunc);
            for (int k = 0; k < N+M; k++) {
                ofs << C[k] << endl;
            }
            ofs.close();
            delete[] C;
 
        }
        
 
        else {
            cout << "Ошибка! Файл не открыт" << endl;
        }
 
        return 0;
        }
    }
1
0 / 0 / 0
Регистрация: 10.12.2018
Сообщений: 25
28.11.2019, 21:39  [ТС]
спасибо за помощь, но сортировка идет неправильно и вообще какая-то абракадабра выходит
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
29.11.2019, 00:56
gogolko, а это и не сортировка вовсе, это дорабтка твоей программы
0
 Аватар для Nishen
1358 / 856 / 366
Регистрация: 26.02.2015
Сообщений: 3,814
29.11.2019, 01:18
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
#include <algorithm>
#include <fstream>
#include <iostream>
#include <iterator>
#include <string>
#include <vector>
 
template<class Iter>
void merge_sort(Iter first, Iter last)
{
    if (last - first > 1) {
        Iter middle = first + (last - first) / 2;
        merge_sort(first, middle);
        merge_sort(middle, last);
        std::inplace_merge(first, middle, last);
    }
}
 
int main() {
 
    const std::string IN_FILE = "AB.txt";
    const std::string OUT_FILE = "C.txt";
 
    std::ifstream file(IN_FILE);
    
    std::vector<int> data;
 
    if (!file) {
 
        std::cerr << "Can't open the file with name " << IN_FILE << '\n';
        return 1;
 
    }
 
    std::copy(std::istream_iterator<int>(file), std::istream_iterator<int>(), std::back_inserter(data));
    file.close();
    merge_sort(data.begin(), data.end());
 
    std::ofstream outFile(OUT_FILE);
    std::copy(data.begin(), data.end(), std::ostream_iterator<int>(outFile, " "));
    
    return 0;
    
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.11.2019, 01:18
Помогаю со студенческими работами здесь

Считывание строк из файла и сортировка , C++
Дело в том , что при считывании из файла последнюю строку считывает 2 раза. Прочитал в интернете мол надо строку очищать чтоб такого не...

Сортировка слиянием - использовать динамические массивы
Добрый день. Хотел бы спросить. На просторах сети нашел код сортировки массива методом слияния. Возможно ли его как то использовать с...

Одномерные массивы: сортировка слиянием и поиск линейным алгоритмом
Задание такое: создать 2 одномерных массива (по 15000 элементов в каждом), после чего отсортировать его его методом слияния. Потом запихать...

Сортировка слиянием из файла
Нашел на просторах форума данный код и дополнил так, что бы он брал числа из файла def mergeSort(alist): if len(alist)&gt;1: ...

Осуществить сортировку текстового файла по длине строк циклическим слиянием/разделением
Осуществить сортировку текстового файла циклическим слиянием/разделением (по длине строк). Файл читается группами по n строк в динамический...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru