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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.93
toljani4x
0 / 0 / 0
Регистрация: 24.09.2009
Сообщений: 15
#1

сортировка массива строк в файле. чтение массива из файла. - C++

24.05.2010, 23:14. Просмотров 1718. Ответов 0
Метки нет (Все метки)

Добрый день форумчане очень нужна ваша помощь.
Собственно надо отсортировать массив из строк по длине первого слова в строке в файле. Записать в файл у меня получилось а считать и отстортировать в файле никак не получается. Собственно это 4 и 5 пункты меню.Если делать без файлов то всё работает. Пожалуйста помогите. Заранее спасибо.
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
// Dynamic_string.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
#include <iomanip>
#include <fstream>
using namespace std;
 
void input_file_name(char* fn,int size_fn);
 
 
int _tmain(int argc, _TCHAR* argv[])
{   
    ofstream fout;
    ifstream fin;
    const int nn=40;
    char fname[nn];
    int size_ps,i,ns;
    char *ps=NULL, **pmas=NULL, **temp=NULL;
    const int n=6;
    char const* pS [ n ] = 
    { "1.Initialize masiive ", "2.show massive ", "3 Zapisj v Fajl","4tenie iz fajla", "5. sortirovka v fajle", "0. Exit" } ;
    int v ;
    do
    {
        cout << "Menu\n" ;
        for ( int i = 0; i < n; i++ ) cout << pS [ i ] << endl ;
        cout << "\nYour choice - > " ;
        cin >> v ;
        cin.get();
        
        switch ( v )
        {
        case 1 : 
        cout<<"koli4estvo strok=";
        cin>>ns;
        cin.get();
        pmas = new char *[ns];
        cout<<"Dlina strok=";
        cin>>size_ps;
        cin.get();
 
        for (int i=0;i<ns;i++)
        pmas[i] = new char[size_ps];
 
        i=0;
    while (i<ns)
    {   
        cout<<i<<" Text=";
        cin.getline(pmas[i],size_ps);
        
        if (*pmas[i]!='\0')
            i++;
        if (cin.fail())
        {
            cin.clear();
            while (cin.get()!='\n');
        }       
    }
    
    cout<<endl;
    break;
        case 2:
            cout<<endl<<'\n';
    for(i=0;i<ns;i++)
    {
        cout<<pmas[i]<<endl;
    }
    cout<<endl;
            break;
        case 3:
 
            input_file_name(fname,nn);
            fout.open(fname);
            
            if (fout.good()==false)
            {               
            cout<<"Can't open file for writing!";
            cin.get();
            fout.close();
            fout.clear();
            }
 
            else
            {
            for(i=0;i<ns;i++)
            {
                fout<<pmas[i]<<endl;
            }
            }
            fout.close();
            break;
        case 5:
            input_file_name(fname,nn);
            cout<<fname<<endl;
            fin.open(fname);
 
            if (fin.good()==false)
            {               
            cout<<"Can't open file for reading!";
            cin.get();
            fin.close();
            fin.clear();
            }
            else
            {
            fin.seekg(0);
            temp=new char *[0];
            for(int j=0;j<ns;j++)
            {
                for(int k=1;k<ns;k++)
                {
                    int i=0;
                    while(pmas[k][i]!=' ')
                        i++;
                    int i1=0;
                    while(pmas[k-1][i1]!=' ')
                        i1++;
                    if(i<i1)
                    {
                        temp[1]=pmas[k];
                        pmas[k]=pmas[k-1];
                        pmas[k-1]=temp[1];
                    }
 
                }
            }
                fin.close();
            if (fin.eof()==true)
                {               
                cout<<"End of file at reading!";
                cin.get();
                fin.clear();
                }
            }
            cin.get();
        break;
        case 4:
            input_file_name(fname,nn);
            cout<<fname<<endl;
            fin.open(fname);
 
            if (fin.good()==false)
            {               
            cout<<"Can't open file for reading!";
            cin.get();
            fin.close();
            fin.clear();
            }
            else
            {
            fin.seekg(0);
            for(i=0;i<ns;i++)
            {
                fin>>pmas[i];
                cout<<pmas[i]<<endl;
            }
            fin.close();
            if (fin.eof()==true)
                {               
                cout<<"End of file at reading!";
                cin.get();  
                fin.clear();
                }
            }
            cin.get();
            break;
        case 0:
        for (i=0;i<ns;i++)
        delete [] pmas[i];
        delete [] pmas;
        delete [] ps;
        break;
        }
    } while ( v != 0 ) ;
    return 0;
}
 
void input_file_name(char* fn,int size_fn)
{
            cout<<"Enter the name of file: ";
            cin.getline(fn,size_fn);
            if (cin.fail()==true)       
                {
                    cin.clear();
                    while (cin.get()!='\n');
                }
}
Добавлено через 5 часов 39 минут
помогите пожалуйсто всё перероблвал а то до экзамена не допустят
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.05.2010, 23:14     сортировка массива строк в файле. чтение массива из файла.
Посмотрите здесь:

Сортировка массива строк - C++
Здравствуйте!Не могу разобраться с сортировкой массива строк по алфавиту! Ввести массив из n строк и n столбцов, отсортировать по...

Сортировка массива строк - C++
Задание: Заполнить заранее проинициализированный массив строк фамилиями своей группы (не по порядку). Отсортировать все фамилии после вашей...

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

Сортировка массива си-строк - C++
есть код #include &lt;iostream&gt; #include &lt;algorithm&gt; using namespace std; int main(int argc, char **argv) { const int...

Сортировка строк массива - C++
На форуме есть множество тем о сортировке массивов, но конкретно под свое решение я способа не нашел. Нужна функция, которая сортирует...

Сортировка строк массива - C++
Задание:отсортировать по не возрастанию предпоследнюю строку массива. Массив 5*6. Вывести массив после обработки. Я представляю как это...

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

Чтение массива из файла - C++
Здравствуйте, подскажите, пожалуйста почему не происходит чтение из файла #include &lt;cstdlib&gt; #include &lt;iostream&gt; #include...

Чтение массива из файла - C++
Здравствуйте, у меня есть массив arr, как я могу прочитать в него из файла следующую запись 0111000011 0000011011 0100011000 ...

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


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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