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

Работа с файлами - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Поиск повторяющихся (строковых) элементов в массиве http://www.cyberforum.ru/cpp-beginners/thread109517.html
Друзья помогите пожалуйста встала такая задача. Есть 3 файла со строчками нужно найти и вывести строчки которые повторяються и вывести сколько раз. Сделал 2 файла. Считал с них инфу в массив, а вот...
C++ Передача значения и передача переменной объясните мне разницу...и с кодами пожалуйста...думаю передача значений это через ссылки\указатели,а передача переменных-переменных Добавлено через 2 минуты у кого есть С++ за 21 день откройте... http://www.cyberforum.ru/cpp-beginners/thread109506.html
C++ двусвязный линейный список
Здравствуйте мне надо реализовать добавление, удаление, редактирование, и поиск!! первые два я уже сделал, а вот с поиском и редактирование не получается помогите пожалуйста))!! Здесь дана...
Работа над множествами C++
Суть состоит в том, чтобы считать 2 множества и сделать соотв. операцию Считывание вроде написал, алгоритм операций знаю, но вот как их реализовать...... *задумался* вот пока что у меня есть...
C++ Заменить все положительные элементы массива, кратные пяти, на максимальный элемент http://www.cyberforum.ru/cpp-beginners/thread109438.html
Требования к выполнение контрольной работы: 1. Каждый пункт меню и вывод текста меню выполняется в подпрограмме. 2. Если в начале работы сразу выбирается пункт ниже первого (массив не задан),...
C++ Как быть дальше? День добрый. Собственно сложилась такая ситуация - Имеется огромное желание изучать дальше языки программирование, и все то, что с ними связано. Возможно около месяца назад, стал изучать С++.... подробнее

Показать сообщение отдельно
MustangGT
1 / 1 / 0
Регистрация: 08.11.2009
Сообщений: 56
29.03.2010, 23:36  [ТС]
а как сделать сортировку выбором по ключу
C++
1
tel[i].data
???????
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
#include <iostream.h>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#include <io.h>
FILE *fl;
typedef struct
{
char marka[30];
char data[10];
char gotovnost[10];
 } TTel;
TTel tel[30]; // Массив структур
char name[20]; // Имя файла
int nst = 0; // Число введенных структур
int Menu(); // Создание меню
void Nnf(); // Ввод имени файла
void Newf(); // Создание нового файла
void Spisok(); // Формирование файла
void Opf(); // Открытие файла
void Resc(); // Вывод результата на экран
void Resf(); // Вывод результата в файл
void S_Vb();
int main()
{
while (true)
{
switch (Menu())
{
case 1: Nnf(); break;
case 2: Newf(); break;
case 3: Spisok(); break;
case 4: Opf(); break;
case 5: Resc(); break;
case 6: Resf(); break;
case 7: S_Vb(); break;
case 8: return 0;
default: puts("Viberite pravilno!");
}
puts ("Press any key to continue");
getch (); // Ожидание нажатия любой клавиши
system ("cls"); // Очистка экрана
}
}
int Menu() // Меню
{
cout << "VIBERITE:" << endl;
cout << "1. Vvod file name" << endl;
cout << "2. New file" << endl;
cout << "3. Vvesti spisok" << endl;
cout << "4. Open file" << endl;
cout << "5. Vivesti result" << endl;
cout << "6. Vivesti v fail" << endl;
cout << "7. Sortirovka Viborom" << endl;
cout << "8. Exit" << endl;
int i;
cin >> i; // Ввод выбранного пункта меню
return i;
}
void Nnf() // Ввод имени файла
{
cout << "Vvedite file name" << endl;
cin >> name;
}
void Newf() // Создание нового файла
{
if ((fl = fopen(name,"wb")) == NULL)
{
cout << "Oshibka pri sozdanii" << endl;
exit(1);
}
cout << "OK" << endl;
fclose(fl);
}
void Spisok() // Ввод данных в файла
{
if ((fl = fopen(name,"rb+")) == NULL)
{
cout << "Oshibka pri sozdanii" << endl;
exit(1);
}
cout << "Vvedite kol-vo televizorov" << endl;
cin >> nst;
for (int i=0; i<nst; i++)
{
cout << "Vvedite marky: ";
cin >> tel[i].marka;
cout << "Vvedite datu_priema: ";
cin >> tel[i].data;
cout << "Vvedite sost_gotovnosti: ";
cin >> tel[i].gotovnost;
fwrite (&tel[i], sizeof(TTel), 1, fl);
}
fclose (fl);
}
void Opf() // Открытие бинарного файла
{
if ((fl = fopen (name,"rb")) == NULL)
{
cout << "Oshibka pri otkritii" << endl;
exit(1);
}
nst = 0;
TTel std;
while (true)
{
int nwrt = fread (&std, sizeof(TTel), 1, fl);
if (nwrt != 1) break;
tel[nst] = std;
cout << tel[nst].marka << " " << tel[nst].data << " "
<< tel[nst].gotovnost << endl;
nst++;
}
fclose(fl);
}
void Resc() // Вывод результата на экран
{
for (int i=0; i<nst; i++)
if (!strcmp (tel[i].gotovnost, "ne_gotov"))
cout << tel[i].marka << tel[i].data <<tel[i].gotovnost << endl;
}
void Resf() // Вывод результата в текстовый файл
{
char namet[30];
FILE *ft;
cout << "Vvedite imya faila" << endl;
cin >> namet;
if ((ft = fopen (namet,"w")) == NULL)
{
cout << "Oshibka pri sozdanii" << endl;
exit(1);
}
char s[80];
for (int i=0; i<nst; i++)
if (!strcmp (tel[i].gotovnost, "ne_gotov"))
{
strcpy (s, tel[i].marka);
strcat (s, "\n"); // Добавление разделителя строк
fputs (s, ft);
}
fclose(ft);
}
 
 
void S_Vb(int tel[], int nst) //вот эт вот не катит....
{ int imin, i, j, t;
for(i = 0; i < nst-1; i++) // Перебор элементов
{
imin = i;
for (j = i+1; j < nst; j++) // Поиск минимального элемента
if (tel[imin] > tel[j])
imin = j;
if (imin != i) { // Перемещение минимального элемента
t = tel[imin];
tel[imin] = tel[i];
tel[i] = t;
}
}
}
Или мот у кого есть целые задачи с примером выполнения сортировки выбором...чтоб понять смысл операторов и функций..Сам то смысл сортировки понятен...(но это блин не яблоки)))))....А то у мне в методичке кусок голого кода....А что к чему не знаю...оч хочется самому до етого додумать...
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru