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

При добавлении студента, сбивается вся структура, и при выводе всего списка студентов, выводит какой то мусор - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Простой парсер - как перебрать варианты строки http://www.cyberforum.ru/cpp-beginners/thread1234636.html
Всем привет!Опыт программирования на си++ всего месяц-c# около 4 а делфи один год.Решил их кинуть(c# и делфи) и писать все на си++.Если что я 12 летний школьник поэтому обьясните попонятней.VCL знаю...
C++ Не выполняется код в цикле в приведенном коде Не могу понять, почему не выполняется код в цикле в этом коде: // sp_Ch5P255_Exercise05 /// Занятия по книге Стивена Праты "Язык программирования С++" (2012, 6-е издание). /// Упражнения по... http://www.cyberforum.ru/cpp-beginners/thread1234627.html
C++ Передача параметра по константной ссылке - что это?
объясните мне пожалуйста что такое передача параметра в функцию по константной ссылке? я просто вообще не могу представить что значит & в параметре функции... 2 года как изучаю си, а такое увидел...
C++ Задание директории gcc
Здравствуйте. Первый раз работаю с gcc. Не получается задать директорию для работы. То есть собирается только то, что лежит в C:\MinGW\bin, а это неудобно. Предполагаю, что надо найти какую-то...
C++ Послать дополнительный клик мышкой http://www.cyberforum.ru/cpp-beginners/thread1234523.html
Вот есть рабочий код void __fastcall TfMain::reTextContextPopup(TObject *Sender, TPoint &MousePos, bool &Handled) { tagINPUT *i = new tagINPUT; //вариант 1 i->type = 0; i->mi.dx =...
C++ Можно ли сделать так чтобы к классу можно было бы одновременно обращаться как к массиву подскажите можно ли сделать так чтобы к классу можно было бы одновременно обращаться как к массиву? т.е. не массив классов я имею ввиду, а что то типа класса TStrings в делфи, т.е. к элементу класса... подробнее

Показать сообщение отдельно
andreyananas
22 / 22 / 9
Регистрация: 15.10.2013
Сообщений: 862
Завершенные тесты: 2

При добавлении студента, сбивается вся структура, и при выводе всего списка студентов, выводит какой то мусор - C++

26.07.2014, 22:14. Просмотров 516. Ответов 18
Метки (Все метки)

Суть действий:
При добавлении студента, сбивается вся структура, и при выводе всего списка студентов, выводит какой то мусор.
Раньше я прописал все тоже самое только без функции AddStudent и все нормально работало(



C++
1
2
3
4
5
6
7
8
9
10
11
12
        case 50: // добавление студента
        {
            AddStudent(stud, &nSize); // добавляем студента
 
            Student ** ppTemp = new Student*[nSize]; 
            for (int i(0); i < nSize; ++i)
                ppTemp[i] = &stud[i];
            delete[] ppStud;
            ppStud = ppTemp;
 
            break;
        }

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void AddStudent(Student * stud, int * nSize)
{
    int dSum(0);
    Student * pStemp = new Student[*nSize + 1];
    memcpy(pStemp, stud, sizeof(Student)*(*nSize));
    delete[] stud;
    stud = pStemp;
 
 
    cout << " Enter name new student: ";
    cin >> stud[*nSize].sName;
    cout << " Enter surname new student: ";
    cin >> stud[*nSize].sSurname;
    stud[*nSize].iYear = 1985 + rand() % 11;
    for (int i(0); i < MARKS_NCOUNT; ++i)
    {
        stud[*nSize].Marks[i] = 1 + rand() % 6;
        dSum += stud[*nSize].Marks[i];
    }
    stud[*nSize].dAverage = dSum / MARKS_NCOUNT;
    *nSize += 1;
}


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
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
// Tabl_students_sort.cpp : Defines the entry point for the console application.
// Таблица студентов
 
 
#include "stdafx.h"
#include <iostream>
#include <time.h>
#include <iomanip>
#include <conio.h>
 
using namespace std;
 
const int NAME_SIZE = 14;
const int MARKS_NCOUNT = 5;
const int COUNT = 12;
const int LET = 3;
 
struct Student
{
    char sName[NAME_SIZE];
    char sSurname[NAME_SIZE];
    int iYear;
    int Marks[MARKS_NCOUNT];
    double dAverage;
};
 
void Init(Student *, int nSize);
void Show(Student * stud, int nSize);
void Show(Student ** ppStAr, int nSize);
void Show(int Index, Student * stud);
void TopAverage(Student * stud, int nSize);
void EditStud(Student * stud, int nSize);
void AddStudent(Student * stud, int * nSize);
void SortYear(Student ** ppStud, int nSize);
void SortSurname(Student ** ppStud, int nSize);
 
 
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    srand((unsigned int)time(0));
    int nSize, choice, menu, ErrorName(0);
    double dSum(0);
 
    cout << " Enter how many students you want [2 - 30]: ";
    cin >> nSize;
 
    if (nSize > 30)
        nSize = 30;
    else if (nSize < 2)
        nSize = 2;
 
    Student * stud = new Student[nSize];
    Init(stud, nSize); // инициализация 
 
    Student ** ppStud = new Student*[nSize];//выделяем память для указателя на указатель (что бы сортировать студентов без копирования их)
    for (int i(0); i < nSize; ++i)
        ppStud[i] = &stud[i]; // инициализируем указатели адресом указателя на структуры
 
    do
    {
        system("cls");
        cout << " \n\n\t   MENU:" << endl;
        cout << " To view the date of all students, press --- \"1\"" << endl;
        cout << " To add students, press -------------------- \"2\"" << endl;
        cout << " To edit the data of students, press ------- \"3\"" << endl;
        cout << " To sorting the data of students, press ---- \"4\"" << endl;
        cout << " To sorting the surname of students, press - \"5\"" << endl;
        cout << " To exit, press ---------------------------- \"ESC\"\n\n" << endl;
        menu = _getch();
        switch (menu)
        {
        case 49: // вывод списка студентов
        {
            Show(stud, nSize); // показываем
            cout << endl;
            TopAverage(stud, nSize);
            cout << endl;
            break;
        }
        case 50: // добавление студента
        {
            AddStudent(stud, &nSize); // добавляем студента
 
            Student ** ppTemp = new Student*[nSize]; 
            for (int i(0); i < nSize; ++i)
                ppTemp[i] = &stud[i];
            delete[] ppStud;
            ppStud = ppTemp;
 
            break;
        }
        case 51: // редактирование
        {
            EditStud(stud, nSize); // редактируем
            break;
        }
        case 52: // сортировка по году рождения
        {
            SortYear(ppStud, nSize); // сортировка указателей 
            cout << endl;
            Show(ppStud, nSize);
            break;
        }
        case 53: // сортировка по фамилии
        {
            SortSurname(ppStud, nSize); 
            cout << endl;
            Show(ppStud, nSize);
            break;
        }
        case 27: // выход из программы
        {
            delete[] ppStud;
            delete[] stud;
            return 0;
            break;
        }
        }
        cout << endl;
        cout << " Press \"ESC\" to exit from program or press any key to return in start menu... " << endl;
        choice = _getch();
    } while (choice != 27);
    delete[] ppStud;
    delete[] stud;
    return 0;
}
 
void Init(Student* pStud, int nSize) // инициализация структуры
{
    char * sNames[COUNT] = { "Andrey", "Sergey", "Alex", "Evgeniy", "Anna", "Alena", "Mike", "Igor", "Kate", "Oleg", "Dima", "Kolya" };
    int iInd;
    for (int i(0); i < nSize; ++i)
    {
        iInd = rand() % COUNT;
        int iLen = strlen(sNames[iInd]) + 1;
        memcpy(pStud[i].sName, sNames[iInd], iLen);
    }
 
    char * sSurnames[COUNT] = { "Ivanenko", "Petrenko", "Shevchenko", "Putin", "Medvedev", "Poroshenko", "Yarosh", "Milevsky", "Blohin", "Surkis", "Levchenko", "Kyrylenko" };
    for (int i(0); i < nSize; ++i)
    {
        iInd = rand() % COUNT;
        int iLen = strlen(sSurnames[iInd]) + 1;
        memcpy(pStud[i].sSurname, sSurnames[iInd], iLen);
    }
 
    for (int i(0); i < nSize; ++i)
        pStud[i].iYear = 1985 + rand() % 11;
 
    double dSum(0);
    for (int i(0); i < nSize; ++i)
    {
        for (int j(0); j < MARKS_NCOUNT; ++j)
        {
            pStud[i].Marks[j] = rand() % 5 + 1;
            dSum += pStud[i].Marks[j];
        }
        pStud[i].dAverage = dSum / MARKS_NCOUNT;
        dSum = 0;
    }
 
}
 
void Show(Student * stud, int nSize) // димонстрация в табл. структуры Student
{
    char hor(196), ver(179), krest1(195), krest2(180), rowDown1(192), rowDown2(217), rowUp1(218), rowUp2(191), space(32); // линии
    const int N = 55;
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << rowUp1;
    for (int i(0); i < N; ++i)
        cout << hor;
    cout << rowUp2 << endl;
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << ver << "    Name:      Surname:    Year:    Marks:   Average:  " << ver << endl;
 
    for (int i(0); i < nSize; i++)
    {
        for (int j(0); j < 3; j++)
            cout << space;
        cout << krest1;
        for (int j(0); j < N; ++j)
            cout << hor;
        cout << krest2 << endl;
 
        for (int j(0); j < 3; j++)
            cout << space;
        cout << ver << setw(9) << stud[i].sName << setw(14) << stud[i].sSurname << "   " << setw(5) << stud[i].iYear << "   ";
        for (int j(0); j < MARKS_NCOUNT; ++j)
            cout << stud[i].Marks[j] << " ";
        cout << "   " << setw(3) << stud[i].dAverage;
        cout << "     " << ver << endl;
    }
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << rowDown1;
    for (int i(0); i < N; ++i)
        cout << hor;
    cout << rowDown2 << endl;
}
 
void Show(Student ** ppStAr, int nSize) // Show для указателя на указатель
{
    char hor(196), ver(179), krest1(195), krest2(180), rowDown1(192), rowDown2(217), rowUp1(218), rowUp2(191), space(32); // линии
    const int N = 55;
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << rowUp1;
    for (int i(0); i < N; ++i)
        cout << hor;
    cout << rowUp2 << endl;
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << ver << "    Name:      Surname:    Year:    Marks:   Average:  " << ver << endl;
 
    for (int i(0); i < nSize; i++)
    {
        for (int j(0); j < 3; j++)
            cout << space;
        cout << krest1;
        for (int j(0); j < N; ++j)
            cout << hor;
        cout << krest2 << endl;
 
        for (int j(0); j < 3; j++)
            cout << space;
        cout << ver << setw(9) << ppStAr[i]->sName << setw(14) << ppStAr[i]->sSurname << "   " << setw(5) << ppStAr[i]->iYear << "   ";
        for (int j(0); j < MARKS_NCOUNT; ++j)
            cout << ppStAr[i]->Marks[j] << " ";
        cout << "   " << setw(3) << ppStAr[i]->dAverage;
        cout << "     " << ver << endl;
    }
 
    for (int i(0); i < 3; i++)
        cout << space;
    cout << rowDown1;
    for (int i(0); i < N; ++i)
        cout << hor;
    cout << rowDown2 << endl;
}
 
void Show(int Index, Student * stud) // показуем инфу студента данные которого будем редактировать
{
    system("cls");
    cout << " Name: " << stud[Index].sName << endl;
    cout << " Surname: " << stud[Index].sSurname << endl;
    cout << " Year: " << stud[Index].iYear << endl;
    cout << " Marks: ";
    for (int i(0); i < MARKS_NCOUNT; i++)
        cout << stud[Index].Marks[i] << ' ';
    cout << endl;
}
 
void TopAverage(Student * stud, int nSize) 
{
    int Index(0);
    double Max(0);
    for (int i(0); i < nSize; ++i)
        if (Max < stud[i].dAverage)
        {
            Max = stud[i].dAverage;
            Index = i;
        }
    for (int i(0); i < nSize; ++i)
        if (Max == stud[i].dAverage)
            cout << "\tAverage mark: " << stud[i].sName << ' ' << stud[i].sSurname << " = " << stud[i].dAverage << endl; //показываем ТОП среднюю оценку
}
 
void EditStud(Student * stud, int nSize) // функция редактирования данных студентов
{
    char SerchName[NAME_SIZE] = "";
    char SerchSurname[NAME_SIZE] = "";
    cout << " Enter name student what want edit: ";
    cin >> SerchName;
    cout << " Enter surname student what want edit: ";
    cin >> SerchSurname;
 
    int Index;
    for (int i(0); i < nSize; ++i)
    {
        if (0 == strcmp(stud[i].sSurname, SerchSurname)) // ищем студента 
        {
            if (0 == strcmp(stud[i].sName, SerchName)) // проверяем совпадает Фамилия с Именем студента
            {
                Index = i;
                break;
            }
        }
        else if (i == nSize - 1)
        {
            cout << SerchName << ' ' << SerchSurname << " - NOT FOUND! " << endl; // выход из функции, если такого студента нету
            return;
        }
    }
 
    Show(Index, stud); // показываем данные студента, которые хотим изменить
    cout << endl;
    cout << " Enter name [2 - 14]: ";
    cin >> stud[Index].sName;
    cout << " Enter Surname [2 - 14]: ";
    cin >> stud[Index].sSurname;
    cout << " Enter year [4 digits]: ";
    cin >> stud[Index].iYear;
    cout << " Enter five ratings [1 - 5]: ";
    double dSum(0);
    for (int i(0); i < MARKS_NCOUNT; ++i)
    {
        cin >> stud[Index].Marks[i];
        dSum += stud[Index].Marks[i];
    }
    stud[Index].dAverage = dSum / MARKS_NCOUNT;
}
 
void AddStudent(Student * stud, int * nSize)
{
    int dSum(0);
    Student * pStemp = new Student[*nSize + 1];
    memcpy(pStemp, stud, sizeof(Student)*(*nSize));
    delete[] stud;
    stud = pStemp;
 
 
    cout << " Enter name new student: ";
    cin >> stud[*nSize].sName;
    cout << " Enter surname new student: ";
    cin >> stud[*nSize].sSurname;
    stud[*nSize].iYear = 1985 + rand() % 11;
    for (int i(0); i < MARKS_NCOUNT; ++i)
    {
        stud[*nSize].Marks[i] = 1 + rand() % 6;
        dSum += stud[*nSize].Marks[i];
    }
    stud[*nSize].dAverage = dSum / MARKS_NCOUNT;
    *nSize += 1;
}
 
void SortYear(Student ** ppStud, int nSize) // сортировка году рождения
{
    int nMin, iMinInd;
    Student * pTemp;
    for (int i = 0; i < nSize; ++i)
    {
        nMin = ppStud[i]->iYear;
        iMinInd = i;
        for (int j = i + 1; j < nSize; ++j)
            if (nMin > ppStud[j]->iYear)
            {
                nMin = ppStud[j]->iYear;
                iMinInd = j;
            }   
        pTemp = ppStud[iMinInd];
        ppStud[iMinInd] = ppStud[i];
        ppStud[i] = pTemp;
    }
}
 
void SortSurname(Student ** ppStud, int nSize) // сортировка фамилии
{
    int iMinInd;
    Student * pTemp;
    for (int i = 0; i < nSize; ++i)
    {
        iMinInd = i;
        for (int j = i + 1; j < nSize; ++j)
            if (0 > strncmp(ppStud[j]->sSurname, ppStud[iMinInd]->sSurname, LET)) // сравниваем первые 3 буквы фамилии
                iMinInd = j;
        if (i != iMinInd)
        {
            pTemp = ppStud[iMinInd];
            ppStud[iMinInd] = ppStud[i];
            ppStud[i] = pTemp;
        }
    }
}
Добавлено через 2 часа 22 минуты
help me)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru