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

Проблема с двусвязным кольцом

17.05.2023, 14:46. Показов 395. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Такая проблема.

Требуется создать двусвязное кольцо следующей структуры:

Группа:
Название(строка);
Код специальности(строка);
Студент*(голова списка);
Студент:
ФИО(строка);
Номер зачетки(число);

Программа должны иметь следующие функции:
1. Добавить группу 6. Вывод
2. Удалить группу 7. Очистить все
3. Добавить студента в группу 8. Выход
4. Удалить студента из группы
5. Редактировать студента в группе

Проблема в том, что если в группе один студент, то программа не может его удалить и выдает, что такого студента не существует. Также еще при выборе 7 функции программа завершает работу и выдается ошибка APPCRASH. В чем может быть проблема, и помогите, пожалуйста, ее исправить. Заранее благодарю.

Мой код:
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
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
#include <iostream>
#include <string>
 
using namespace std;
 
 
struct Student {
    string Name;
    int Number;
    Student* next;
    Student* prev;
};
 
struct Group {
    string Name;
    string Number;
    Student* student = NULL;
    Group* next;
    Group* prev;
};
 
void setGroup(Group** group){
    cout << "Введите название группы: " << endl;;
    getline(cin >> ws, (*group) -> Name);
    cout << "Введите код специальности: " << endl;;
    getline(cin, (*group) -> Number);
    (*group)->student = NULL;
}
 
void setStudent(Student** student){
    cout << "Введите номер зачетки: " << endl;
    cin >> (*student)->Number;
    cout << "Введите ФИО студента: " << endl;;
    getline(cin >> ws, (*student)->Name);
}
 
void addFirst(Group** head){
    Group* group = new Group;
    setGroup(&group);
    if ((*head) != NULL){
        if ((*head)->next == *head) { (*head) -> next = group; }
        group -> next = *head;
        group -> prev = (*head) -> prev;
        (*head)->prev->next = group;
        (*head)->prev = group;
        *head = group;
        return;
    }
    *head = group;
    group -> next = *head;
    group -> prev = *head;
}
    
Group* getGroupAddress(string NameOfGroup, Group* head) {
    Group* group = head;
    string curGroup = group->Name;
    while ((NameOfGroup.compare(curGroup) != 0) && (group->next != head)) {
        group = group->next;
        curGroup = group->Name;
    }
    if (NameOfGroup.compare(curGroup) == 0) {
        return group;
    }
    return 0;
}
 
Student* getStudentAddress(int NumOfZach, Group* head) {
    Group* group = head;
    Student* stud = group->student;
    while (stud->Number != NumOfZach && stud->next != NULL) {
        stud = stud->next;
    }
    return (stud->Number == NumOfZach) ? stud : NULL;
}
 
void addStudent(Group** groupHead){
    Student* stud = new Student;
    string name;
    cout << "Введите название группы: ";
    getline(cin >> ws, name);
    Group* group = getGroupAddress(name, *groupHead);
    if (group == 0) {cout << "Такой группы не существует!" << endl; return;}
    setStudent(&stud);
    stud->next = group->student;
    *&(group->student) = stud;
}
 
void removeStudentFront(Group** head){
    Student* prevStud = (*head)->student;
    (*head)->student = prevStud -> next;
    delete prevStud;
}
 
void removeStudent(Group** groupHead){
    int studIndex;
    string groupNumber;
    cout << "Введите название группы:";
    getline(cin >> ws, groupNumber);
    Group* group = getGroupAddress(groupNumber, *groupHead);
    if (group == NULL) {cout << "Такой группы не существует!" << endl;; return;}
    if (group->student == NULL) {cout << "Error" << endl;;}
    cout << "Введите номер зачетки студента: ";
    cin >> studIndex;
    Student* left = group->student;
    Student* stud = group->student;
    if (studIndex == 1) {removeStudentFront(&group); return;}
    left = getStudentAddress(studIndex, group);
    if (left == NULL || left->next == NULL) {cout << "Такого студента нет!" << endl; return;}
    stud = left->next;
    left->next = stud->next;
    stud->next = left;
    delete stud;
    stud = NULL;
}
 
void removeGroup(Group** groupHead){
    string num;
    cout << "Введите название группы:";
    getline(cin >> ws, num);
    Group* group = getGroupAddress(num, *groupHead);
    if (group == NULL) {cout << "Такой группы не существует!" << endl; return;}
    Student* stud = group->student;
    Student* studAddress = stud;
    while(studAddress != NULL){
        delete stud;
        studAddress = studAddress -> next;
        stud = studAddress;
    }
    delete studAddress;
    if (group == *groupHead){
        Group* prevGroup = *groupHead;
        *groupHead = prevGroup -> next;
        (*groupHead)->prev = prevGroup->prev;
        (*groupHead)->prev->next = *groupHead;
        delete prevGroup;
        return;
    }
    group->next->prev = group->prev;
    group->prev->next = group->next;
    delete group;
}
 
void clearAll(Group** groupHead){
    Group* groupAddress = (*groupHead);
    Group* group = groupAddress;
    if (groupAddress == NULL) return;
        do{
            groupAddress = group;
            Student* stud = groupAddress->student;
            Student* studAddress = stud;
            while(studAddress != NULL){
                delete stud;
                studAddress = studAddress -> next;
                stud = studAddress;
            }
            delete studAddress;
            delete groupAddress;
            group = group->next;
        }while(groupAddress->next != (*groupHead));
        delete group;
        delete groupAddress;
        *groupHead = NULL;
        cout << "Удаление выполнено!" << endl;;
}
 
void editStudent(Group** groupHead){
    int studIndex;
    string groupNumber;
    cout << "Введите название группы:";
    getline(cin >> ws, groupNumber);
    Group* group = getGroupAddress(groupNumber, *groupHead);
    if (group == NULL) {cout << "Такой группы не существует!" << endl; return;}
    cout << "Введите номер зачетки студента: ";
    cin >> studIndex;
    Student* stud = group->student;
    stud = getStudentAddress(studIndex, group);
    if (stud == NULL) {cout << "Такого студента нет!" << endl;; return;}
    setStudent(&stud);
}
 
void showList(Group* head) {
    if (head == NULL) return;
    Group* Cur = head;
    Student* stud = Cur->student;
    while (Cur != head);{
        Cur = Cur->prev;
        stud = Cur->student;
        cout << "Группа: " << Cur->Name << endl;
        cout << "Специальность: " << Cur->Number << endl;
        cout << "Студенты: " << endl;
    while(stud != NULL){
        cout << "ФИО: " << stud->Name << endl;
        cout << "Номер зачетки: " << stud->Number << endl;
        stud = stud->next;
    }
    }
}
 
int main() {
    
    setlocale(LC_ALL, "Russian");
    
    Group* groupList = NULL;
    char ans = 'Y';
    int func;
    
    while (ans != 'Y' || ans != 'y') {
        cout << "1.Добавить группу." << endl;
        cout << "2.Удалить группу." << endl;
        cout << "3.Добавить студента в группу." << endl;
        cout << "4.Удалить студента из группы." << endl;
        cout << "5.Редактированть студента в группе." << endl;
        cout << "6.Вывод." << endl;
        cout << "7.Очистиь все." << endl;
        cout << "8.Выход." << endl;
        cin >> func;
        
        if(func == 1) {
            addFirst(&groupList);
        }
        else if(func == 2) {
            removeGroup(&groupList);
        }
        else if(func == 3) {
            addStudent(&groupList);
        }
        else if(func == 4) {
            removeStudent(&groupList);
        }
        else if(func == 5) {
            editStudent(&groupList);
        }
        else if(func == 6) {
            showList(groupList);
        }
        else if(func == 7) {
            clearAll(&groupList);
        }
        else if(func == 8) {
            return 0;
        }
        else {
            cout << "Введена неверная команда!" << endl;
            return 0;
        }
        cout << "Хотите продолжить: ";
        cin >> ans;
    }
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.05.2023, 14:46
Ответы с готовыми решениями:

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

Проблема с двусвязным списком
Всееем добрый вечер! Подскажите, пожалуйста, в чём здесь ошибка? Код запускается и работает, но...

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

Является ли эта алгебраическая система кольцом / ассоциативным / коммутативным кольцом?
На множестве M заданы операции сложения и умножения, такие что: + a b 1 0 * a b 1 0...

2
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
20.05.2023, 14:34 2
Цитата Сообщение от ivan_2004 Посмотреть сообщение
то программа не может его удалить и выдает, что такого студента не существует.
В 108-й строке вторая часть условия так и записана, а 106-я противоречит заданию. Номера зачёток - не индексы.

Тебе надо учитывать все случаи раздельно: не найден, найден и находится в (начале списка, середине, конце).
0
0 / 0 / 0
Регистрация: 14.12.2022
Сообщений: 20
21.05.2023, 20:21  [ТС] 3
nmcf, Спасибо за ответ. Наверное вы правы. Только я не понял, как это можно сделать.
0
21.05.2023, 20:21
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
21.05.2023, 20:21
Помогаю со студенческими работами здесь

Проблема с двусвязным списком
Начал изучать создание классов и столкнулся с проблемой. Создал двусвязный список по примеру из...

Является ли множество кольцом
являеться ли множество a+b\sqrt{5}:a,b\in Z? если да то образует ли область целостности и являеться...

Является ли (Z, +, *, <) упорядоченным кольцом?
Помогите, пожалуйста. Является ли (Z, +, *, &lt;) упорядоченным кольцом, если a &lt; b &lt;=&gt; -a &lt; -b ?

Задача с двусвязным списком
Задача с двусвязным списком Напишите программу, вычисляющую сумму значений n элементов, начиная...

Функция с двусвязным списком
Всем доброго времени суток! Вот задание: Дан указатель P на первый элемент непустого...

Тестирование по двусвязным спискам
Я два вопроса додумать не могу... может кто придумает?)

Работа с двусвязным списком
Если использую в качестве value целочисленный тип данных, то код работает. Переделал, чтобы в...


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

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