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

Реализация БД для работы со студентами. Taking fire, need assistance! - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Написать программу для решения уравнения http://www.cyberforum.ru/cpp-beginners/thread1003801.html
y=sin(2x+1) х от -3 до 1 го, шаг 0,2 нужно решить функцию нужно на этой неделе, пожалуйста помогите
C++ задача на условие Задача на условие, помогите срочно( спасибо) http://www.cyberforum.ru/cpp-beginners/thread1003792.html
Перегрузка функций C++
Есть функция Message которую я пытаюсь перегрузить. Вроде все правильно, но не работает:cry: . Помогите разобраться. Ошибка на 44 и 45 строчку. #include <time.h> #include <iostream> #include <conio.h> #include <iomanip> using namespace std; class mass_bool { private: const int iLenght, iWidth, iHeight;
C++ VPTR
Как следует решать данную задачу?
C++ Ошибка error LNK2019: http://www.cyberforum.ru/cpp-beginners/thread1003748.html
Не могу понять с чего выдает эту ошибку. Все правильно задано ! В чем дело никто не подскажет? index.obj : error LNK2019: ссылка на неразрешенный внешний символ "struct IntegerMap * __cdecl IntegerMapCreate(int)" (?IntegerMapCreate@@YAPAUIntegerMap@@H@Z) в функции _main 1>index.obj : error LNK2019: ссылка на неразрешенный внешний символ "void __cdecl IntegerMapDestroy(struct IntegerMap *)"...
C++ Перегруженные функции. Создать под код программы Вот под это нужно создать перегруженную функцию В одномерном массиве, состоящем из п элементов, вычислить: 1) произведение положительных элементов массива; 2) сумму элементов массива, расположенных до минимального элемента. // Лабораторная работа 1.3.2.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" подробнее

Показать сообщение отдельно
l7tu4ka
0 / 0 / 0
Регистрация: 18.04.2012
Сообщений: 6
10.11.2013, 20:34     Реализация БД для работы со студентами. Taking fire, need assistance!
Суть задания в том, что БД нужно реализовать в консоли С++, используя структуры(VS 2010).
Нужна помощь в дописании кода вместо комментариев.
Сам код:
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
#include <iostream>
#include <conio.h>
#include <Windows.h>
using namespace std;
 
//--------------------------------------------------
 
//Написать программу, реализующую БД для работы со студентами
//Реализовать:
//  Добавление студентов в БД
//  Удаление студентов:
//              - по номеру записи
//              - по фамилии
 
//  Отображение всех записей БД
//      Поля: ФИО, группа, рейтинг
//      или по группам.
 
//  Сортировка записей:
//      - по алфавиту
//      - по рейтингу от большего к меньшему
//      - группе и ФИО одновременно
 
struct Stud
{
    char FIO[80];
    char Group[10];
    float Rating;
};
 
Stud *pstud = NULL;
int size=0;
 
void Add()
{
    Stud *arr = new Stud[size+1];
    memcpy(arr,pstud,sizeof(Stud)*size);
 
    delete[] pstud;
    pstud = arr;
    size++;
}
 
void Del()
{
    cout<<"Выберите вариант удаления:\n"<<
            "1. По номеру в списке\n"<<
            "2. По ФИО\n";
    int choice;
    int ind;
    choice=_getch();
    switch(choice)
    {
    case '1':
        cout<<"Введите номер списка: ";
        cin>>ind; cin.get();
        Stud *arr = new Stud[size-1];
        memcpy(arr,pstud,sizeof(Stud)*ind);
        memcpy(arr+ind,pstud+ind,sizeof(Stud)*(size-ind-1));
 
        delete[] pstud;
        pstud = arr;
        size--;
        break;
        case '2':
                //
                //код удаления по фамилии
                //
                break;
    }
}
 
void Show(const Stud &d)
{
    cout<<" "<<d.FIO<<"\t\t\t"<<d.Group<<"\t\t"<<d.Rating<<endl;
}
 
Stud Input()
{
    Stud d;
    cout<<"Ф.И.О.: ";
    cin.getline(d.FIO,80);
    OemToCharA(d.FIO,d.FIO);
    cout<<"Группа: ";
    cin.getline(d.Group,10);
    OemToCharA(d.Group,d.Group);
    cout<<"Рейтинг: ";
    cin>>d.Rating;
    cin.get();
 
    return d;
}
 
void ShowAll()
{
    cout<<"Выберите вариант показа:\n"<<
            "1. Стандартный\n"<<
            "2. По группам\n";
    int choice;
    choice=_getch();
    switch(choice)
    {
    case '1':
        cout<<"   Ф.И.О.:\t\t\t\t\tГруппа:\t\tРейтинг: "<<endl;
        for(int i=0;i<size;i++)
        {
            cout<<i+1<<'.';
            Show(pstud[i]);
        }
        cout<<endl;
        break;
        case '2':
                //
                //код показа по группам
                //
                break;
    }
}
 
int CmpFIO(const void* p1, const void* p2)
{
    Stud* pp1 = (Stud*)p1;
    Stud* pp2 = (Stud*)p2;
 
    return strcmp(pp1->FIO,pp2->FIO);
}
 
int CmpGroup(const void* p1, const void* p2)    
{
    Stud* pp1 = (Stud*)p1;
    Stud* pp2 = (Stud*)p2;
 
    return strcmp(pp1->Group,pp2->Group);
}
 
int CmpRating(const void* p1, const void* p2)   
{
    //сравнение по рейтингу
}
 
void Sort()
{
    cout<<"Выберите вариант сортировки:\n"<<
            "1. По алфавиту\n"<<
            "2. По рейтингу\n"<<
            "3. По группе и ФИО\n";
    int choice;
    choice=_getch();
    switch(choice)
    {
    case '1':
        system("cls");
        qsort(pstud,size,sizeof(Stud),CmpFIO);                                              
        ShowAll();
        _getch();
        system("cls");                              
        break;                                      
    case '2':
        system("cls");
        //
        //функция сортировки по рейтингу
        //
        ShowAll();
        _getch();
        system("cls");                              
        break;  
    case '3':
        system("cls");
        qsort(pstud,size,sizeof(Stud),CmpGroup);
        if(CmpGroup==0)
        qsort(pstud,size,sizeof(Stud),CmpFIO);
        ShowAll();
        _getch();
        system("cls");                               
        break;
    }
}
 
void main()
{
    setlocale(LC_ALL,"");
 
    int choice;
    do
    {
        cout<<"Выберите пункт меню:\n";
        cout<<"1. Добавить запись студента\n"<<
                "2. Удалить запись студента\n"<<
                "3. Показать все записи\n"<<
                "4. Сортировка записей\n"<<
                "5. Выход\n";
        choice=_getch();
        system("cls");
        switch(choice)
        {
        case '1':
            system("cls");
            Add();
            cout<<"Введите данные:\n";
            pstud[size-1]=Input();
            system("cls");
            break;
        case '2':
            system("cls");
            Del();
            ShowAll();
            _getch();
            system("cls");
            break;
        case '3':
            system("cls");
            ShowAll();
            _getch();
            system("cls");
            break;
        case '4':
            Sort();
            break;
        case '5':
            exit(0);
        }
    }
    while(true);
}

Начальное меню:
Миниатюры
Реализация БД для работы со студентами. Taking fire, need assistance!  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru