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

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

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

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

24.05.2010, 23:14. Просмотров 1728. Ответов 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 минут
помогите пожалуйсто всё перероблвал а то до экзамена не допустят
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.05.2010, 23:14
Здравствуйте! Я подобрал для вас темы с ответами на вопрос сортировка массива строк в файле. чтение массива из файла. (C++):

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

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

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

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

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

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

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.05.2010, 23:14
Привет! Вот еще темы с ответами:

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

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

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

Чтение из файла массива - C++
Пожалуйста помогите разобрать чтение двумерного масиива из файла(не могу найти чтото понятное(


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

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

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