Помогите пожалуйста, не могу запустить. Выбивает постоянно ошибку при запуске и не могу понять почему. Вот условие:
В спортивных соревнованиях участвуют
n команд. В файле SPORT содержатся
прогнозы результатов соревнований. Каждый прогноз включает номер команды, занявшей
первое место, номер команды, занявшей последнее место, номера команд, входящих
в первую тройку сильнейших команд. Построить таблицу, содержащую проценты
голосов, отданных командам - претендентам на первое место, командам -
претендентам на последнее место и проценты голосов, отданных командам -
претендентам на первую тройку. Организовать таблицу как таблицу с
вычисляемым входом.
Вот уже готовый код:
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
| #define _CRT_SECURE_NO_WARNINGS
#include<conio.h>
#include<stdio.h>
#include<math.h>
#define N 20
struct Prognoz {
float first; //определение структур
float last;
float three;
int name;
};
struct Ptable {
Prognoz prognoz[N]; //определение структуры таблица
int n;
}; //фактическое количество
void move(Ptable & table, int i, int j)//функция перестановки 2элементов в таблице {float р; //р присваивается э-т тапбицы
{
float p;
int k;
p = table.prognoz[j].first;
table.prognoz[j].first = table.prognoz[i].first;
table.prognoz[i].first = p;
p = table.prognoz[j].last;
table.prognoz[j].last = table.prognoz[i].last;
table.prognoz[i].last = p;
p = table.prognoz[j].three;
table.prognoz[j].three = table.prognoz[i].three;
table.prognoz[i].three = p;
k = table.prognoz[j].name;
table.prognoz[j].name = table.prognoz[i].name;
table.prognoz[i].name = k;
}
void main() //начало главной ф-ции
{
int num, k = 0, t, max, mid, j; //num-число, котрое считываем из файла, номер комрады: мах - максимаьное баллов на данном этапе:mid сравниваемое с min
float i = 0; //и-счётчик количества элементов
Ptable table; //определение талбицы
FILE *f, *f1;// определение потокв (далее идёт ссылка на поток)
f = fopen("d:\SPORT.txt", "r");
f1 = fopen("d:\RESULT.txt", "w"); //открываем файлы
for (k = 0; k < N; k++) //обнуляем таблицу результатов
{
table.prognoz[k].first = 0;
table.prognoz[k].last = 0;
table.prognoz[k].three = 0;
table.prognoz[k].name = k + 1;
}
while (!(feof(f))) //пока не конец файла
{
fscanf(f, " %d ", &num); //считываем и прибавляем команде с соотв. номером единицу
table.prognoz[num - 1].first = table.prognoz[num - 1].first + 1;
fscanf(f, " %d ", &num); if (num>N)printf("table full\n");
table.prognoz[num - 1].last = table.prognoz[num - 1].last + 1;
fscanf(f, " %d ", &num); if (num>N)printf("table full\n");
table.prognoz[num - 1].three = table.prognoz[num - 1].three + 1;
fscanf(f, " %d ", &num); if (num>N)printf("table full\n");
table.prognoz[num - 1].three = table.prognoz[num - 1].three + 1;
fscanf(f, " %d ", &num); if (num>N)printf("table full\n");
table.prognoz[num - 1].three = table.prognoz[num - 1].three + 1;
i++;
}
for (k = 0; k<N; k++) //начало цикла сортировки
{
max = table.prognoz[k].first + table.prognoz[k].three - table.prognoz[k].last; //пристваиваем максимаьному значению значение первое неотсортированной части
t = k;
for (j = k + 1; j<N; j++) //мы проходим всю неотсортированную часть в поиске макс
{
mid = table.prognoz[j].first + table.prognoz[j].three - table.prognoz[j].last;
if (mid>max)
{
t = j;
max = mid;
}
}
move(table, t, k);
}
fprintf(f1, "#team first last three");
for (k = 0; k<N; k++)
{
fprintf(f1, "\nteam#%d", table.prognoz[k].name);
table.prognoz[k].first = table.prognoz[k].first / i * 100;
fprintf(f1, " %.1f", table.prognoz[k].first);
table.prognoz[k].last = table.prognoz[k].last / i * 100;
fprintf(f1, " %.1f", table.prognoz[k].last);
table.prognoz[k].three = table.prognoz[k].three / i * 100;
fprintf(f1, " %.1f", table.prognoz[k].three);
}
fclose(f);
fclose(f1);
} |
|
Помогите пожалуйста, очень нужна помощь)
SPORT.txt