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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ В матрице из целых чисел поменять местами первую строку и строку, содержащую самый большой по абсолютной величине элемент матрицы http://www.cyberforum.ru/cpp-beginners/thread885896.html
В матрице из целых чисел поменять местами первую строку и строку, содержащую самый большой по абсолютной величине элемент матрицы. Массив динамический.
C++ Надо перевести программу из ПАСКАЛЯ в СИ uses crt; var a:array of integer; m,n,i,j,k,m1,n1,q1,q2:integer; c:integer; begin clrscr; randomize; k:=0; writeln('Введите размер массива:'); write('Строк-');readln(m); http://www.cyberforum.ru/cpp-beginners/thread885889.html
произведение и сумма C++
Ребят,может может кто помочь или хотя бы объяснить,или примером показать как эти суммы и произведения считать и писать...Заранее спасибо всем
C++ Построить таблицу значений функции y=f(x) для x из [a,b] с шагом h
Построить таблицу значений функции y=f(x) для x из с шагом h. Если в некоторой точке функция не определена, то вывести сообщение об этом. (Использовать исключения) Сама функция: у = (x + 4)/(x*x -2) + sqrt(x*x*x -1)
C++ Удалить из массива элементы, в записи которых все цифры различны http://www.cyberforum.ru/cpp-beginners/thread885847.html
Удалить из массива элементы, в записи которых все цифры различны. (Желательно использовать вектора)
C++ Подправить код Помогите пожалуйста, нужно подправить код: /* Дана целочисленная квадратная матрица. Опередить: 1) произведение элементов в тех строках, которые не содержат отрицательных элементов. 2) максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы. */ #include <iostream.h> int main() { int N; // размер массива подробнее

Показать сообщение отдельно
takecashman
1 / 1 / 0
Регистрация: 23.05.2013
Сообщений: 33
31.05.2013, 01:04     Для студентов 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru