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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
#1

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

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

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

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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.05.2013, 01:04
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Для студентов 1 курсов - Курсовая (создать структуру, элементами которой являются фамилия студента и его возраст) (C++):

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

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

Как создать структуру-список, поля которой — ссылка на такую же структуру - C++
Суть вопроса в том, как создать структуру-список, поля которой - ссылка на сл. элемент(такую же структуру) и ссылка на объект, относящийся...

Известна информация о группе студентов - Фамилия, имя, год рождения, пол, рост. объявить и инициализировать структуру , позволяющую отобразить информа - C++
Вот с прошлого семестра валялась на компе задачка, приложил максимум усилий чтобы её написать. Сколько нервов, а преподша так и не...

Составить квадратную матрицу, элементами которой являются кубы чисел от 1 до 25 - C++
Задание: составить квадратную матрицу элементами которой являются кубы чисел от 1-25. У меня выходит 1 1 1 1 1 8 8 8 8 8 27 27...

Задача (использование и функций, и процедур) формирования матрицы M[i,j], элементами которой являются: - C++
помогите пожалуйста решить в С++ Задача (использование и функций, и процедур) формирования матрицы M, элементами которой являются: -...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Максим2001
7 / 7 / 1
Регистрация: 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
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
31.05.2013, 02:24  [ТС] #3
И где же то, что ты исправил ?

Добавлено через 1 минуту
Вообще-то это ПОЛНОСТЬЮ рабочая программа без ошибок. Я выложил специально для людей, которым попадется похожее задание !
0
Максим2001
7 / 7 / 1
Регистрация: 11.01.2012
Сообщений: 85
31.05.2013, 02:33 #4
Вообще-то она была с ошибками:
1. При запуске программы компилятор (VC++) выдавал ошибку - она пыталась подключиться к iostream.h, в то время как подключаются к просто <iostream>. То же самое со всеми остальными функциями.
2. При вводе сразу двух студентов программа зацикливалась.
3. На настроенных компах выводила иероглифы.
0
MrGluck
Модератор
Эксперт CЭксперт С++
7239 / 4407 / 642
Регистрация: 29.11.2010
Сообщений: 11,927
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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.05.2013, 02:42
Привет! Вот еще темы с ответами:

Составить структуру, состоящую из полей – фамилию студента и 3 его оценок по экзаменам - C++
Составить структуру, состоящую из полей – фамилию студента и 3 его оценок по экзаменам (например русский, математика, ...

Получить действительную квадратную матрицу порядка 8, элементами которой являются числа a1,., a64 - C++
Нужно заполнить матрицу &quot;змейкой&quot;, начиная с правого верхнего угла. Код уже есть, но постоянно выскакивает ошибка, которую самостоятельно я...

Получить квадратную матрицу порядка n, элементами которой являются числа b1,...,bn^n., расположенные по схеме - C++
1) Дано последовательность чисел b1,...bn . Получить квадратную матрицу порядка n, элементами которой являются числа b1,...,bn^n. ,...

Получить действительную матрицу порядка 8, элементами которой являются числа а1.а64 расположенные по схеме - C++
Даны действительные числа а1..а64. Получить действительную матрицу порядка 8, элементами которой являются числа а1..а64 расположенные в ней...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
31.05.2013, 02:42
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru