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

Ошибка при заполнении массива структур - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Ссылка на неразрешённый файл http://www.cyberforum.ru/cpp-beginners/thread1065829.html
Задание: Для заданной квадратной матрицы найти такие k, что k-я строка матрицы совпадает с k-м столбцом. На скриншоте выделил красным ошибку, как исправить? Подскажите пожалуйста!) Частенько эта ошибка вылезает.
C++ Не могу разобраться с ошибкой Всю голову переломал почему он ругается на cout в 11 строке. Подскажите пожалуйста. #include <iostream.h> #include <conio.h> #include <math.h> void main () { float a,h,c; a=1; h=0,5; c=3.14; cout <<"Predislovie "; while (a>=1 && a<=3) { http://www.cyberforum.ru/cpp-beginners/thread1065824.html
Упорядочить элементы главной диагонали перестановкой столбцов C++
Упорядочить элементы главной диагонали квадратичной матрицы(n x n) перестановкой столбцов n=5. Элементы матрицы случайные действительные числа в диапазоне от -10 до 10
C++ Error C2181: недопустимый else без парного if
Помогите! Не могу понять в чем ошибка! Стоит задача: Напишите один оператор if, который проверяет две целочисленные переменные и присваивает переменной с большим значением меньшее значение, используя только один дополнительный оператор else вот то что я написал! #include<iostream> using namespace std; int mail() { int x, y;
C++ проверить код на с++ http://www.cyberforum.ru/cpp-beginners/thread1065808.html
проверьте код, а то не могу понять в чем ошибка, почему не запускается #include <iostream.h> #include <math.h> #include <iomanip.h> #include <conio.h> int main () { double i; cout << "Enter a, h: ";
C++ Нахождения кратчайших путей между всеми парами вершин графа Подскажите как можно улучшить алгоритм Флойда-Уоршелла что-бы он верно работал если длина некоторых векторов равно 0 (то есть отсутствую). Добавлено через 1 час 45 минут for (int k=0; k<n; ++k) for (int i=0; i<n; ++i) for (int j=0; j<n; ++j) if (d < INF && d < INF) d = min (d, d + d); Вот я что-то нашел. Но не могу в этом коде разобраться. Источник кода:... подробнее

Показать сообщение отдельно
AnSm
 Аватар для AnSm
3 / 3 / 1
Регистрация: 30.09.2013
Сообщений: 32
08.01.2014, 17:06     Ошибка при заполнении массива структур
Доброго времени суток и Всех с Новогодними праздниками!

В моем задании нужно ввести массив строк символов про успеваемость студентов: фамилия, №зачетки и оценки с 5 предметов. Переписать массив структур в двунаправленный список, записать его в файл и вывести на экран. Кроме этого посчитать средний бал по 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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#define k 5             // количество оценок
 
typedef struct student
{
    char *name;         
    int zalikovka;      
    int bal[5];         
} stud;             
 
typedef struct  list{
    stud std;           // Поле даних
    struct list *next, *prev;   // вказівники на попередній і наступний елементи
} list;             // структура опису двозв'язного списку
 
void ReadStrings(char a[][40], int n);      
void Rozbuttia(char info[][40],stud a[],int n); 
list* NewElement(stud a);               
void InsertElem(list *pnew);            
void SortList();                        
void WriteToFile();                 
void ReadFromFile();                    
list *Head, *Tail;                  
 
void main()
{
    int n,i,bs;
    stud a[10];                 // массив структур
    char info[10][40];              // массив строк
    printf ("How much students add ");
    scanf("%d", &n);                // читаем количество студентов
    fflush(stdin);              // очищаем буфер клавиатуры
    ReadStrings(info, n);           // мситываем строки
    Rozbuttia(info, a, n);          // создаем массив структур
    for (i=0;i<n;i++)
        InsertElem(NewElement(a[i]));   // создаем двусвязный список
    SortList();                 // сортируем список
    WriteToFile();                  // заносим список в файл
    ReadFromFile();             // выводим информацию из файла на экран
    printf ("\n Input bal: ");
    scanf("%d", &bs);
    putchar('\n');
    system ("PAUSE");               // пауза
}
/***********************************************************************************/
 
void ReadStrings(char a[][40], int n)
{
    printf("Input information about Students in next format \n");
    for (int i=0;i<=55;i++) putch('-');
    printf("\n \Surname \Zalikova Bal[1] Bal[2] Bal[3] Bal[4] Bal[5]\"\n");
    for (int i=0;i<=55;i++) putch('-');
    putchar('\n');
    for (int i=0;i<n;i++)
            gets(a[i]);         // читаем строку        
}
/***********************************************************************************/
 
void Rozbuttia(char info[][40],stud a[],int n)
{
    int i,j;
    for (i=0;i<n;i++)                       // цикл по рядках
    {
        a[i].name=strtok(info[i]," ");          // виділяємо прізвище
        a[i].zalikovka=atoi(strtok(NULL," "));      // виділяємо номер заліковки
        for (j=0;j<k;j++)                   
            a[i].bal[j]=atoi(strtok(NULL," ")); // виділяємо оцінки
    }
}
 
/***********************************************************************************/
 
list* NewElement(stud a)
{
    list *pel;
    pel = new list;             // виділяємо динамічну пам'ять
    pel->std=a;                 // заповнюємо інформаційне поле елемента
    pel->next=pel->prev=NULL;           // занулюємо показники 
    return pel;                 // вертаємо елемент
}
 
/***********************************************************************************/
 
void InsertElem(list* pnew)
{
    if (Head==NULL)             // якщо список пустий
    {
        pnew->next=pnew->prev=NULL;     // занулюємо вказівники
        Head=Tail=pnew;         // Голова і хвіст вказують на перший елемент
    }
    else 
    {
        Tail->next=pnew;            // хвіст вказує на вхідний елемент
        pnew->prev=Tail;            // вказівник попереднього на хвіст
        pnew->next=NULL;            // вкзівник наступного на NULL
        Tail=pnew;              // Хвіст вказує на потчний
    };
}
 
/***********************************************************************************/
 
void SortList()
{
list *tmp, *a;
    stud t;                     // 0 – замін не було, 1 – була заміна
    int flag=1;                 // флажок чи була проведена заміна
    while(flag==1)                  // цикл чи була проведена заміна
    {
        tmp=Head;                   // темп вказує на голову
        a=tmp->next;                    // а вказує на наступний елемент
        flag=0;                 // занулюємо флажок
        while(a)                    // поки а не дорівнює NULL
        {
    if((tmp->std.name)>(a->std.name)) // якщо наступний номер менший за попередній
            {
          t=tmp->std;               // заміна інформаційних полів
                tmp->std=a->std;
                a->std=t;                           
                flag=1;             // встановлюємо флаг в 1
            }
            tmp=tmp->next;              // перехід до наступного елемента
            a=a->next;              // перехід до наступного елемента
        }
    }
}
 
/***********************************************************************************/
 
void WriteToFile()
{
    FILE *fp;                   // файлова змінна
    char *way={"C:\\Users\Anastacia\Desktop\result.txt"};       // шлях до файлу
    fp=fopen(way, "a");             // відкритя файлу
    list *temp=Head;                // темп вказує на голову
    while (temp!=NULL)              // прохід по списку
    {
        fprintf (fp, "%15s%8d%3d%3d%3d%3d%3d\n",temp->std.name, temp->std.zalikovka, 
                        temp->std.bal[0], temp->std.bal[1], temp->std.bal[2], 
                        temp->std.bal[3], temp->std.bal[4]);    // запис в файл
        temp=temp->next;            // перехід до наступного елемента
    }
    fclose(fp);                 // закриття файлу
} 
 
/***********************************************************************************/
 
void ReadFromFile()
{
    FILE *fp;                       // файлова змінна
    int i=0, ser;
    char *way={"C:\\Users\Anastacia\Desktop\result.txt"}, temp[1][40];  // шлях до файлу, масив з одного рядка
    stud temp1[1];                                                      // інформаційна структура 
    for (i=0;i<55;putchar('-'),i++);                    
    printf ("\n       Surname  Zalikova [1] [2] [3] [4] [5] Seredne\n");
    for (i=0;i<55;putchar('-'),i++);            
    putchar('\n');                  
    fp=fopen(way, "r");                 // відкриваємо файл для читання
    while (fgets(temp[0], 40, fp)!=NULL)        // цикл по рядках файлу
    {
Rozbuttia(temp,temp1,1);            // розбиваємо зчитаний рядок на поля
    ser=(temp1->bal[0]+temp1->bal[1]+temp1->bal[2]+temp1->bal[3]+temp1->bal[4])/k ;
    printf("%15s%9d%5d%4d%4d%4d%4d%4d\n", temp1->name, temp1->zalikovka,  
                temp1->bal[0], temp1->bal[1], temp1->bal[2], temp1->bal[3], temp1->bal[4], ser);
    ser=0;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru