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

Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) - C++

Восстановить пароль Регистрация
 
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
31.05.2013, 01:04     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) #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
#include <iostream.h>
#include <string.h>
#include <fstream.h>
 
/**********************************************
 * Структура "Студент" с фамилией и возрастом *
 **********************************************/
 
struct Student {
    char name[100];
    int age;
};
 
/**********************************************************
 * Заранее объявленые функции - по функции на пункт меню  *
 * Полные описания функций - ниже по тексту, после main() *
 **********************************************************/
 
// Ввод новых студентов 
// Все параметры передаются по ссылке, т.к. функция меняет их.
void input( Student * & students, int & N );
 
// Вывод списка студентов на экран или в файл
// Куда выводить, определяет третий параметр
void output( Student * students, int N, ostream & stream );
 
// Упорядочить студентов по алфавиту
void sort( Student * students, int N );
 
// Вывести список студентов в файл
void toFile( Student * students, int N );
 
// Главная программа
void main() {
    
    // Массив студентов. Изначально не существует
    Student * students = NULL;
    // Количество студентов 
    int N = 0;
    
    // Действие (выбрвнное в меню)
    int action;
    
    for( ; ; ) { // Повторять вечно
    
        // Вывод меню
        cout << "Количество студентов: " << N << endl;
        cout << "1. Добавить студентов" << endl;
        cout << "2. Вывод списка" << endl;
        cout << "3. Сортировка" << endl;
        cout << "4. Запись в файл" << endl;
        cout << "0. Конец работы" << endl;
        cout << "Действие: ";
        
        // Ввод действия
        cin >> action;
        
        // action = 0 - выход
        if( ! action )
            break;
            
        // Вызов соответствующей функции
        switch( action ) {
            case 1:
                input( students, N );
                break;
            case 2:
                output( students, N, cout );
                break;
            case 3:
                sort( students, N );
                break;
            case 4:
                toFile( students, N );
                break;
            default:
                cout << "Неизвестное действие" << endl;
        }
    }
    
    // Освобождение памяти
    // NB: если ptr = NULL, то delete ptr не делает ничего
    delete students;
}
 
 
// Ввод новых студентов 
// Все параметры передаются по ссылке, т.к. функция меняет их.
void input( Student * & students, int & N ) {
    
    // Ввод количества новых студентов
    int M;
    cout << "Сколько новых студентов будет введено: ";
    cin >> M;
    if( M <= 0 )
        return;
        
    int i;
    
    // Изменение размера массива
    if( N == 0 ) // Если массива ещё нет
 
        students = new Student[ M ]; // создаём его
 
    else { // Если массив уже есть
 
        Student * tmp = students;
 
        // Создаём новый массив на M длиннее
        students = new Student[ N + M ];
        
        // Копируем старый массив в новый
        for( i = 0; i < N; ++ i )
            students[ i ] = tmp[ i ];
        
        // Освобождаем память, занятую старым массивом
        delete tmp;
    }
    
    // Ввод новых студентов
    for( i = 0; i < M; ++ i ) {
        cout << ( i + 1 ) << ". Фамилия: ";
        cin >> students[ N + i ].name;
        cout << ( i + 1 ) << ". Возраст: ";
        cin >> students[ N + i ].age;
    }
    
    // Забываем старый размер массива, меняем на новый
    N += M;
}
 
 
// Вывод списка студентов на экран или в файл
void output( Student * students, int N, ostream & stream ) {
    for( int i = 0; i < N; ++ i )
        stream << ( i + 1 ) << ". " << students[ i ].name << "; "
            << students[ i ].age << endl;
}
 
// Упорядочить студентов по алфавиту
/*
    Применяем простейший метод - "сортировку пузырьком".
    Суть:
    Проходим массив от первого студента до предпоследнего.
    Если студент должен стоять по алфавиту после следующего студента,
        меняем их местами.
    В результате одного такого прохода самый последний по алфавиту студент
        оказывается последним в массиве ("всплывает", как пузырёк).
    Повторяем ту же операцию опять, но последнего студента в массиве не
        трогаем. "Всплывает" предпоследний студент. И так далее, пока
        не останется только один студент.
*/
void sort( Student * students, int N ) {
    int i, j;
    Student tmp;
    for( i = N - 1; i > 0; -- i )
        for( j = 0; j < i; ++ j )
            if( strcmp( students[ j ].name, students[ j + 1 ].name ) > 0 ) {
                tmp = students[ j ];
                students[ j ] = students[ j + 1 ];
                students[ j + 1 ] = tmp;
            }
    cout << "Студенты отсортированы." << endl;
}
 
// Вывести список студентов в файл
void toFile( Student * students, int N ) {
    
    char fileName[ 100 ];
    
    // Спрашиваем имя файла
    cout << "Имя файла: ";
    cin >> fileName;
    
    // Создаём файл
    ofstream file( fileName );
    
    // Выводим туда массив (та же функция применялась для вывода на экран)
    output( students, N, file );
    
    // Закрываем файл.
    file.close();
    cout << "Файл записан." << endl;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.05.2013, 01:04     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст)
Посмотрите здесь:

Создать структуру Время с элементами Часы, Минуты C++
C++ Получить квадратную матрицу порядка n, элементами которой являются числа b1,...,bn^n., расположенные по схеме
Известна информация о группе студентов - Фамилия, имя, год рождения, пол, рост. объявить и инициализировать структуру , позволяющую отобразить информа C++
C++ Создать структуру, элементами которой являются фамилия студента и оценки
C++ Задача (использование и функций, и процедур) формирования матрицы M[i,j], элементами которой являются:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Максим2001
7 / 7 / 1
Регистрация: 11.01.2012
Сообщений: 85
31.05.2013, 02:13     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) #2
Ты реализовал, и хочешь чтоб исправили ошибки? За тобой

Добавлено через 15 минут
Здесь исправлены все твои ошибки и баги (для Visual C++):

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
#include <iostream>
#include <string>
#include <fstream>
#include <ostream>
#include <istream>
#include <locale>
 
/**********************************************
 * Структура "Студент" с фамилией и возрастом *
 **********************************************/
 
using namespace std;
 
struct Student {
    char name[100];
    int age;
};
 
/**********************************************************
 * Заранее объявленые функции - по функции на пункт меню  *
 * Полные описания функций - ниже по тексту, после main() *
 **********************************************************/
 
// Ввод новых студентов 
// Все параметры передаются по ссылке, т.к. функция меняет их.
void input( Student * & students, int & N );
 
// Вывод списка студентов на экран или в файл
// Куда выводить, определяет третий параметр
void output( Student * students, int N, ostream & stream );
 
// Упорядочить студентов по алфавиту
void sort( Student * students, int N );
 
// Вывести список студентов в файл
void toFile( Student * students, int N );
 
// Главная программа
void main() {
    setlocale(LC_ALL, "rus");
    // Массив студентов. Изначально не существует
    Student * students = NULL;
    // Количество студентов 
    int N = 0;
    
    // Действие (выбрвнное в меню)
    int action;
    
    for(bool b = 1;b;) { // Повторять вечно
        // Вывод меню
        cout << "Количество студентов: " << N << endl;
        cout << "1. Добавить студентов" << endl;
        cout << "2. Вывод списка" << endl;
        cout << "3. Сортировка" << endl;
        cout << "4. Запись в файл" << endl;
        cout << "0. Конец работы" << endl;
        cout << "Действие: ";
        
        // Ввод действия
        cin >> action;
        
        // action = 0 - выход
        if( action == 0 )
            break;
            
        // Вызов соответствующей функции
        switch( action ) {
            case 1:
                input( students, N );
                break;
            case 2:
                output( students, N, cout );
                break;
            case 3:
                sort( students, N );
                break;
            case 4:
                toFile( students, N );
                break;
            default:
                cout << "Неизвестное действие" << endl;
        }
    }
    
    // Освобождение памяти
    // NB: если ptr = NULL, то delete ptr не делает ничего
    delete students;
}
 
 
// Ввод новых студентов 
// Все параметры передаются по ссылке, т.к. функция меняет их.
void input( Student * & students, int & N ) {
    
    // Ввод количества новых студентов
    int M;
    cout << "Сколько новых студентов будет введено: ";
    cin >> M;
    if( M <= 0 )
        return;
        
    int i;
    
    // Изменение размера массива
    if( N == 0 ) // Если массива ещё нет
 
        students = new Student[ M ]; // создаём его
 
    else { // Если массив уже есть
 
        Student * tmp = students;
 
        // Создаём новый массив на M длиннее
        students = new Student[ N + M ];
        
        // Копируем старый массив в новый
        for( i = 0; i < N; ++ i )
            students[ i ] = tmp[ i ];
        
        // Освобождаем память, занятую старым массивом
        delete tmp;
    }
    
    // Ввод новых студентов
    for( i = 0; i < M; i++ ) {
        cout << ( i + 1 ) << ". Фамилия: ";
        cin >> students[ N + i ].name;
        cout << ( i + 1 ) << ". Возраст: ";
        cin >> students[ N + i ].age;
    }
    
    // Забываем старый размер массива, меняем на новый
    N += M;
}
 
 
// Вывод списка студентов на экран или в файл
void output( Student * students, int N, ostream & stream ) {
    for( int i = 0; i < N; ++ i )
        stream << ( i + 1 ) << ". " << students[ i ].name << "; "
            << students[ i ].age << endl;
}
 
// Упорядочить студентов по алфавиту
/*
    Применяем простейший метод - "сортировку пузырьком".
    Суть:
    Проходим массив от первого студента до предпоследнего.
    Если студент должен стоять по алфавиту после следующего студента,
        меняем их местами.
    В результате одного такого прохода самый последний по алфавиту студент
        оказывается последним в массиве ("всплывает", как пузырёк).
    Повторяем ту же операцию опять, но последнего студента в массиве не
        трогаем. "Всплывает" предпоследний студент. И так далее, пока
        не останется только один студент.
*/
void sort( Student * students, int N ) {
    int i, j;
    Student tmp;
    for( i = N - 1; i > 0; -- i )
        for( j = 0; j < i; ++ j )
            if( strcmp( students[ j ].name, students[ j + 1 ].name ) > 0 ) {
                tmp = students[ j ];
                students[ j ] = students[ j + 1 ];
                students[ j + 1 ] = tmp;
            }
    cout << "Студенты отсортированы." << endl;
}
 
// Вывести список студентов в файл
void toFile( Student * students, int N ) {
    
    char fileName[ 100 ];
    
    // Спрашиваем имя файла
    cout << "Имя файла: ";
    cin >> fileName;
    
    // Создаём файл
    ofstream file( fileName );
    
    // Выводим туда массив (та же функция применялась для вывода на экран)
    output( students, N, file );
    
    // Закрываем файл.
    file.close();
    cout << "Файл записан." << endl;
}
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
31.05.2013, 02:24  [ТС]     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) #3
И где же то, что ты исправил ?

Добавлено через 1 минуту
Вообще-то это ПОЛНОСТЬЮ рабочая программа без ошибок. Я выложил специально для людей, которым попадется похожее задание !
Максим2001
7 / 7 / 1
Регистрация: 11.01.2012
Сообщений: 85
31.05.2013, 02:33     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) #4
Вообще-то она была с ошибками:
1. При запуске программы компилятор (VC++) выдавал ошибку - она пыталась подключиться к iostream.h, в то время как подключаются к просто <iostream>. То же самое со всеми остальными функциями.
2. При вводе сразу двух студентов программа зацикливалась.
3. На настроенных компах выводила иероглифы.
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4925 / 2668 / 243
Регистрация: 29.11.2010
Сообщений: 7,421
31.05.2013, 02:42     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) #5
И то и то ...

C++
1
2
3
4
5
6
7
8
9
#include <iostream>
#include <fstream>
#include <clocale>
#include <cstring>
 
...
 
int main()
{ ...
Добавлено через 1 минуту
Но для первокурсника вполне годно

Добавлено через 1 минуту
// Освобождение памяти
// NB: если ptr = NULL, то delete ptr не делает ничего
delete students;
Ошибочка - undefined behavour по стандарту

Добавлено через 29 секунд
for(bool b = 1;b { // Повторять вечно
C++
1
while(true)
Но логичней было б ввести переменную, отвечающую за выбор пункта меню и работать пока не выбран 0.

Добавлено через 1 минуту
Student * & students
полная бредятина

Добавлено через 1 минуту
Цитата Сообщение от Максим2001 Посмотреть сообщение
students = new Student[ M ]; // создаём его
такие вещи в функции не фабрике делать не хорошо.

Добавлено через 19 секунд
и т.д. и т.п.
Цитата Сообщение от MrGluck Посмотреть сообщение
Но для первокурсника вполне годно
Yandex
Объявления
31.05.2013, 02:42     Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст)
Ответ Создать тему
Опции темы

Текущее время: 11:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru