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

Редактирование и удаление записи - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Цикические однсвязные списки http://www.cyberforum.ru/cpp-beginners/thread1055178.html
Всем доброго времени суток. Очень нужна ваша помощь. Дана задачка. Немного не получается удаление элементов. Прогу писал в вижуал с++. Прилагаю код. N ребят располагаются по кругу. (задать в качестве элементов списка имена). Начав отсчет от первого, удаляют согласно считалке каждого j-го, смыкая при этим круг. Определить порядок удаления ребят из круга, выводя на экран имя и порядковый номер...
C++ Сравнение 3 чисел Всем привет)) В колледже задали задание: написать программу, которая сравнивает 3 числа. Три варианта я сделал: #include <iostream> using namespace std; int main() { int x, y, z, Max; cout << "Введите число x: "; http://www.cyberforum.ru/cpp-beginners/thread1055154.html
C++ Написать функцию сортировки элементов двухмерного массива
Помогите написать код. Опишите функцию сортировки элементов линейного массива. С помощью этой функции составьте программу, которая упорядочивает по убыванию элементы рядков двухмерного массива. Добавлено через 1 час 34 минуты :-)
C++ Пятиминутное дело!В чем ошибка?
В первой строке дано неотрицательное число N- количество элементов массива (N<=100). Во второй строке дано число b Заполнить массив элементами равными частному от деления индекса элемента массива на число b. Элементы массива дробные числа В чем ошибка? #include<stdio.h> #include<conio.h> main() {
C++ Циклы и условие http://www.cyberforum.ru/cpp-beginners/thread1055139.html
Доброго времени суток,прошу помочь написать программу на VS 2005 которая бы в включала цикл и условие. Программа для покейлки обоев 3 комнатной квартире #include <iostream> // Библиотека using std::cout; // Вывод текста на экран using std::cin; // Ввод текста с клавиатуры using std::endl; // Переход на новую строчку int main() { double height=0.0, width=0.0, length=0.0;
C++ Преобразовать каждое слово в строк, заменив в нем все предыдущие вхождения его последней буквы на символ «.» Дана строка, состоящая из слов, набранных заглавными бук-вами и разделенных пробелами (одним или несколькими). Преобразо-вать каждое слово в строк, заменив в нем все предыдущие вхождения его последней буквы на символ «.» (точка). Например, слово «МИ-НИМУМ» надо преобразовать в «.ИНИ.УМ». Количество пробелов между словами не изменять. подробнее

Показать сообщение отдельно
absentio
0 / 0 / 0
Регистрация: 23.12.2013
Сообщений: 2
24.12.2013, 19:02     Редактирование и удаление записи
При нажатии клавиши 3 программа должна удалять данные о студенте (Вводим номер группы - удаляются все записи с данным номером группы);
При нажатии клавиши 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
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
225
// ConsoleApplication1.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <windows.h>
#include <conio.h>
#include <stdio.h>
#include <iostream>
#include <string>
#include <fstream>
#include <ostream>
#include <istream>
 
 
using namespace std;
 
struct Student {
    char name[100];
    char fam[100];
    char otch[100];
    int group;
    float ekz[5];
    float zach1,zach2,zach3,zach4,zach5;
};
 
void input( Student * & students, int & N );
 
void output( Student * students, int N, ostream & stream );
 
void zachet( Student * students, int N, ostream & stream );
 
double sort(Student * students,int N);
 
int editStudent(Student *student, int N, int);//Функция для редактирования*/
 
// Главная программа
void main() {
 SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    // Массив студентов. Изначально не существует
    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 << "5. Вывод данных студента с результатами зачетов." << endl;
        cout << "0. Конец работы." << endl;
        cout << "Ваш выбор: ";
 
        // Ввод действия
        cin >> action;
 
        // action = 0 - выход
        if( action == 0 )
            break;
 
        // Вызов соответствующей функции
        switch( action ) {
            case 1:
                input( students, N);
                break;
            case 2:
 
            case 3:
 
            case 4:
                sort(students, N);
                break;
            case 5:
                zachet(students, N, cout );
                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 << "Фамилия: ";
        cin >> students[ i ].fam;
        cout << "Имя: ";
        cin >> students[ i ].name;
        cout << "Отчество: ";
        cin >> students[ i ].otch;
        cout << "Группа: ";
        cin >> students[ i ].group;
        for(int j=0;j<5;j++)
        {
        cout << "Введите " << j+1 << " оценку за экзамен: ";
        cin >> students[i].ekz[j];
        }
        cout << "Введите результат 1 зачета: ";
        cin >> students[i].zach1;
        cout << "Введите результат 2 зачета: ";
        cin >> students[i].zach2;
        cout << "Введите результат 3 зачета: ";
        cin >> students[i].zach3;
        cout << "Введите результат 4 зачета: ";
        cin >> students[i].zach4;
        cout << "Введите результат 5 зачета: ";
        cin >> students[i].zach5;
    
    }
 
   
 
    // Забываем старый размер массива, меняем на новый
    N += M;
}
 
// Вывод списка студентов на экран или в файл
void output( Student * students, int N, ostream & stream ) 
{
    for( int i = 0; i < N; ++ i )
        stream << ( i + 1 ) << ". " << students[ i ].fam <<" "<<students[ i ].name<<" " << students[ i ].otch<<" " << students[ i ].group<<endl;
 
}
// Упорядочить студентов по алфавиту
 
void zachet( Student * students, int N, ostream & stream ) {
    for( int i = 0; i < N; ++ i )
        stream << ( i + 1 ) << ". " << students[ i ].fam <<" "<<students[ i ].name<<" " << students[ i ].otch<<" " << students[ i ].group<<" " << students[ i ].zach1<<" "<<students[ i ].zach2<<" "<<students[ i ].zach3<<" "<<students[ i ].zach4<<" "<<students[ i ].zach5<<" "<<endl;
}
    
double sort(Student * gr, int N)
{
    double s; //перемееная для подсчета суммы балов каждого студента
    double *avg = new double [N]; //выделяем память под массив хранящщего средние балы каждого студента
 
    //находим средний бал каждого студента
    for(int i = 0; i < N; i++)
    {
        s = 0.;
        for(int j = 0; j < 5; j++)
        {
            s += gr[i].ekz[j];
            avg[i] = s / 5;
        }
    }
 
    bool flag = true; //обьявляем булевую переменную и даем есть значение "истина"
 
        while(flag) //пока "истина" делаем
        {
            flag = false;  //устанавливаем переменную в "ложь"
 
            for(int i = 0; i < N - 1; ++i)
            {
                if(avg[i] > avg[i + 1]) //если элемент массива большн следующий элемент, тогда
                {
                    //меняем массивы в структуре местами
                    Student x = gr[i];
                    gr[i] = gr[i + 1];
                    gr[i + 1] = x;
 
                    //а также меняем местами и элементы в массиве средних оценок
                    double temp = avg[i];
                    avg[i] = avg[i + 1];
                    avg[i + 1] = temp;
 
                    flag = true; //уснанавлюем в "истина"
                }
            }
        }
        //выводим на экран отсортированную структуру
        for(int i = 0; i < N; i++)
    {
        cout << gr[i].fam << ' ' << gr[i].name << ' '<< gr[i].otch << ' '  << gr[i].group;
            for(int j = 0; j < 5; j++)
            {
                cout << ' ' << gr[i].ekz[j];
 
            }
            cout << " " << avg[i]; //выводим на экран средний бал
            cout << endl;
    }
    delete [] avg; //освобождаем память
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 21:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru