Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
6 / 6 / 0
Регистрация: 23.05.2013
Сообщений: 33
1

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

31.05.2013, 01:04. Показов 3468. Ответов 4
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Написать программу, в которой необходимо создать структуру, элементами которой являются фамилия студента и его возраст. Объявить массив данных о студентах группы типа структуры и ввести значения его элементов. Отсортировать массив структур в алфавитном порядке фамилий, входящих в структуру, перемещая сами структуры. Предусмотреть меню. Результаты работы программы записать в файл.

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;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
31.05.2013, 01:04
Ответы с готовыми решениями:

Создать структуру, элементами которой являются фамилия студента и оценки
Вроде бы и не особо сложное задание, но оно вызвало у меня проблемы, т.к. опыта в программировании...

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

Создать структуру, содержащую информацию о горожанине фамилия И.О., дата рождения, адрес. Посчитать возраст.
Здравствуйте. Помогите cоздать структуру, содержащую информацию о горожанине(фамилия И.О., дата...

Создать структуру, содержащую поля: название дисциплины, фамилия студента, оценка
Список содержит сведения о сессии. 1. Создать структуру, содержащую поля: название дисциплины,...

4
7 / 7 / 3
Регистрация: 11.01.2012
Сообщений: 85
31.05.2013, 02:13 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;
}
0
6 / 6 / 0
Регистрация: 23.05.2013
Сообщений: 33
31.05.2013, 02:24  [ТС] 3
И где же то, что ты исправил ?

Добавлено через 1 минуту
Вообще-то это ПОЛНОСТЬЮ рабочая программа без ошибок. Я выложил специально для людей, которым попадется похожее задание !
0
7 / 7 / 3
Регистрация: 11.01.2012
Сообщений: 85
31.05.2013, 02:33 4
Вообще-то она была с ошибками:
1. При запуске программы компилятор (VC++) выдавал ошибку - она пыталась подключиться к iostream.h, в то время как подключаются к просто <iostream>. То же самое со всеми остальными функциями.
2. При вводе сразу двух студентов программа зацикливалась.
3. На настроенных компах выводила иероглифы.
0
Форумчанин
Эксперт CЭксперт С++
8215 / 5045 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
31.05.2013, 02:42 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 Посмотреть сообщение
Но для первокурсника вполне годно
0
31.05.2013, 02:42
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
31.05.2013, 02:42
Помогаю со студенческими работами здесь

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

Вывести на экран фамилию самого старшего студента и средний возраст для всех студентов
Создать файл, элементами которого являются сведения о студентах: фамилия, возраст, место...

Курсовая: создать программный продукт для центра дополнительных курсов
В общем нужен человек, который помог бы выполнить курсоую в Делфи. Задача примерно следующая :...

Создать матрицу, элементами которой являются расстояние между каждой парой данных точек
Здравствуйте. Написал программу, требуется переписать используя вместо функции процедеру. Прошу...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru