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

Проблемы с удалением связанного списка(С++)

05.09.2012, 15:37. Показов 791. Ответов 6
Метки нет (Все метки)

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
#include <iostream>
#include <fstream>
#include <conio.h>
#include <iomanip>
#include <time.h>
#include <string>
 
 
using namespace std;
 
struct rabotnik
{
    string name;
    int staj;
    int zarplata;
    string doljnost;
    rabotnik* next;
};
 
rabotnik* head;
 
rabotnik* zapis(rabotnik *cur,  string P1, string P2, int p1, int p2)
{
    rabotnik* cur2 = new rabotnik; 
    cur2->name =P1; 
    cur2->doljnost=P2;
    cur2->staj=p1;
    cur2->zarplata=p2;
    cur2->next=NULL;
    cur=cur2;
    cur->next = head;
    head = cur;
    return cur;
}
 
rabotnik* promejutok(rabotnik* cur, int vopros)
{
    string P1, P2;
    int p1, p2;
    for (int i=0; i<vopros; i++)
    {
        cout<<endl<<"Введите имя работника ";
        cin >> P1;
        cout<<endl<<"Введите должность работника ";
        cin >> P2;
        cout<<endl<<"Введите стаж работника ";
        cin >> p1;
        while(p1>60||p1<0)
        cout<<endl<<"Введите зар.плату работника(в рублях) ";
        cin >> p2;
        zapis  (cur, P1, P2, p1, p2);
    }
    return(cur);
}
 
void Vivod(rabotnik* q)
{
    q=head;
    for (;q;)
    {
        cout << setw(15) << q->name << setw(15) << q->doljnost << setw(15) << q->staj << setw(15) << q->zarplata ;
        q=q->next;
    }
    cout<<endl;
}
 
void udalenie()
{
    rabotnik* prom;
    do
    {
        prom=head->next;
        delete head;
        head=prom;
    }while (head->next);
    delete head;
}
 
void main()
{
    int vopros=1, vopros1;
    setlocale(0, "");
    system("color F0");
    while(vopros==1)
    {
        cout<<"Введите кол-во рабочих на предприятии ";
        cin>>vopros;
        rabotnik* cur;
        cur=head;
        promejutok(cur, vopros);
        rabotnik* q=new rabotnik;
        Vivod(q);
        udalenie();
        cout<<"Если хотите запустить программу снова, нажмите 1 ";
        cout<<endl<<"ВНИМАНИЕ!";
        cout<<"Если Вы нажмете другую кнопку, программа завершит действие ";
        cin>>vopros;
    }
}
Прошу прощения, если данная тема уже поднималась.
Заранее большое спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.09.2012, 15:37
Ответы с готовыми решениями:

Определить в классе статическую компоненту - указатель на начало связанного списка объектов и функцию просмотра списка
Помогите пожалуйста доделать программу. Необходимо определить в классе статическую компоненту -...

Окончание связанного списка
Скажите, пожалуйста, как в моём случае можно поступить: выйти из цикла, если нажатием Enter ничего...

Стек на основе связанного списка C++
Привет:) Мне нужно разработать функции занесения и извлечения данных стека на основе связанного...

Удаление элемента из связанного списка
Нужно удалить все элементы списка кратные 3. void Del() { if (head == NULL) cout &lt;&lt; &quot;\nСписок...

6
5499 / 4894 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
05.09.2012, 16:14 2
Цитата Сообщение от Писарев Иван Посмотреть сообщение
while(p1>60||p1<0)
cout<<endl<<"Введите зар.плату работника(в рублях) ";
Что это за странный цикл, в котором ничего не меняется? Может так нужно ?
C++
1
2
3
4
5
if (p1 < 60 && p1 > 0)
{
    cout << endl << "Введите зар.плату работника(в рублях) ";
    cin >> p2;
}
Хотя ошибку это не убирает.
1
0 / 0 / 0
Регистрация: 05.09.2012
Сообщений: 44
05.09.2012, 16:21  [ТС] 3
Цитата Сообщение от alsav22 Посмотреть сообщение
Что это за странный цикл, в котором ничего не меняется? Может так нужно ?
C++
1
2
3
4
5
if (p1 < 60 && p1 > 0)
{
    cout << endl << "Введите зар.плату работника(в рублях) ";
    cin >> p2;
}
:
Так оно на самом деле и есть. Просто в задании нужно было еще ставить так называемую "защиту от дурака" и сделать сортировку, но в целях экономии я это вырезал все(сортировка работает верно). Спасибо за замечание.
0
5499 / 4894 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
05.09.2012, 16:43 4
Если так, то, вроде бы, работает:
C++
1
2
3
4
5
6
7
8
9
10
11
void udalenie()
{
    rabotnik* prom;
    do
    {
        prom = head -> next;
        delete head;
        head = prom;
    } while (head);
    delete head;
}
1
0 / 0 / 0
Регистрация: 05.09.2012
Сообщений: 44
05.09.2012, 16:55  [ТС] 5
Цитата Сообщение от alsav22 Посмотреть сообщение
Если так, то, вроде бы, работает:
C++
1
2
3
4
5
6
7
8
9
10
11
void udalenie()
{
    rabotnik* prom;
    do
    {
        prom = head -> next;
        delete head;
        head = prom;
    } while (head);
    delete head;
}
Огромнейшее вам спасибо!
0
Эксперт С++
2924 / 1274 / 114
Регистрация: 27.05.2008
Сообщений: 3,465
05.09.2012, 17:11 6
C++
1
2
3
4
5
6
7
8
9
10
11
void udalenie()
{
    rabotnik* prom;
    do
    {
        prom = head -> next;
        delete head;
        head = prom;
    } while (head);
    // delete head;    <--- вот это уже лишнее, хотя работать все равно будет :-)
}
1
5499 / 4894 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
05.09.2012, 17:20 7
Цитата Сообщение от CheshireCat Посмотреть сообщение
вот это уже лишнее, хотя работать все равно будет
Верно.
0
05.09.2012, 17:20
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.09.2012, 17:20
Помогаю со студенческими работами здесь

Удаление элементов связанного списка
Не работают методы поиска и удаления, сам алгоритм написан правильно, не могу разобраться где...

Создание индекса связанного списка
Доброго времени суток! Требуется создать класс (IndexedList) индекс для улучшения...

Реализация связанного списка - нужны пояснения
#include &lt;iostream&gt; using namespace std; class cool { public: int number;...

Реализация очереди на основе связанного списка
Реализация очереди на основе связанного списка в строках хэдэра tmp-&gt;ch.name = ch1.name; ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на Go/Golang с Kafka и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
UserScript для подсветки кнопок языков программировани­­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форме быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru