С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
Рэмбо комнатный
 Аватар для GeFacle
103 / 103 / 99
Регистрация: 05.03.2017
Сообщений: 511

Удаление всех вхождений числа в список

28.04.2017, 15:40. Показов 1143. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include "stdafx.h"
#include <iostream>
 
using namespace std;
 
struct link
{
    int data;
    link* next;
};
 
class linklist
{
private:
    link* first;
public:
    linklist()
    {
        first = NULL;
    }
    void additem(int d);
    void display();
    void deleteEl(int d);
};
 
void linklist::additem(int d)
{
    link* newlink = new link;
    newlink->data = d;
    newlink->next = first;
    first = newlink;
}
 
void linklist::display()
{
    link* current = first;
    while (current)
    {
        cout << current->data << "->";
        current = current->next;
    }
    cout << "NULL\n";
}
 
void linklist::deleteEl(int d)
{
    link* fir = first;
    link* back = fir;
 
    while (fir->data == d)
    {
        first = fir->next;
        delete fir;
        fir = first;
        back = fir;
    }
 
    while (fir)
    {
        if (fir->data == d)
        {
            back = fir->next;
            delete fir;
        }
        if (fir->data == d && fir->next==NULL)
        {
            delete fir;
            return;
        }
        back = fir;
        fir = fir->next;
    }
}
 
int main()
{
    setlocale(LC_ALL, "rus");
    linklist L;
    int n, m;
    cout << "Сколько элементов введем?";
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        cin >> m;
        L.additem(m);
    }
    L.display();
    cout << "Какой элемент хотите удалить?";
    cin >> n;
    L.deleteEl(n);
    L.display();
    system("pause");
    return 0;
}
поправьте кто-нибудь пожалуйста)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.04.2017, 15:40
Ответы с готовыми решениями:

Удаление из массива всех вхождений первого элемента
Добрый день. Прошу помочь в изменении программы. есть программа, которая изменяет порядок значений массива, в первой половине выводит...

Удаление всех вхождений элемента Х в односвязном списке L
Доброй ночи. Ситуация HELP, ситуация SOS. Есть задача &quot;Написать программу удаление всех вхождений элемента Х в односвязном списке L....

Создать линейный список целых чисел. Вычислить количество вхождений заданного числа в очереди
Создать линейный список целых чисел. Вычислить количество вхождений заданного числа в очереди

2
 Аватар для moskitos80
442 / 99 / 42
Регистрация: 04.10.2011
Сообщений: 359
28.04.2017, 16:32
Под GCC:

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
#include <iostream>
#include <memory>
 
using namespace std;
 
struct link
{
    int data;
    std::shared_ptr<link> next;
};
 
class linklist
{
private:
    std::shared_ptr<link> first;
public:
    linklist();
    void additem(int d);
    void display();
    bool deleteEl(int d);
};
 
 
linklist::linklist(): first{nullptr}
{/* EMPTY */}
 
void linklist::additem(int d)
{
    std::shared_ptr<link> newlink{new link};
    newlink->data = d;
    newlink->next = first;
    first = newlink;
}
 
void linklist::display()
{
    std::shared_ptr<link> current = first;
    while (current) {
        cout << current->data << "->";
        current = current->next;
    }
    cout << "NULL\n";
}
 
bool linklist::deleteEl(int d)
{
    std::shared_ptr<link> curr = first;
    std::shared_ptr<link> prev = curr;
 
    if (curr->data == d) {
        first = curr->next;
        curr.reset();
        return true;
    }
 
    while (curr) {
        if (curr->data != d) {
            prev = curr;
            curr = curr->next;
        } else {
            prev->next = curr->next;
            curr.reset();
            return true;
        }
    }
    return false;
}
 
int main()
{
    setlocale(LC_ALL, "");
    linklist L;
 
    int n, m;
    cout << "Сколько элементов введем?";
    cin >> n;
 
    for (int i = 0; i < n; i++) {
        cin >> m;
        L.additem(m);
    }
 
    L.display();
    cout << "Какой элемент хотите удалить?";
    cin >> n;
 
    if (L.deleteEl(n)) {
        L.display();
    } else {
        cerr << "Элемент не найден";
    }
 
    return 0;
}
1
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
28.04.2017, 16:41
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
void linklist::deleteEl(int d)
{
    node* temp;
 
    while (first->data == d)
    {
        temp = first->next;
        delete first;
        first = temp;
    }
 
    if( first == nullptr )
        return;
 
    node* prev = first;
    while (prev->next)
    {
        if (prev->next->data == d)
        {
            temp = prev->next->next;
            delete prev->next;
            prev->next = temp;
        }
        else
            prev = prev->next;
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.04.2017, 16:41
Помогаю со студенческими работами здесь

Удаление дерева (помещение всех его элементов в список свободного пространства)
Удаление дерева, т.е. помещение всех его элементов в список свободного пространства....нужна помошь

Связный список, поиск вхождений, зацикленность
Надо найти входит ли один список в другой, но функция циклится, не пойму, как это обойти bool eq_int(List **L1, List **L2) { List*...

Подсчитать число вхождений элемента в список
Условие: Описать функцию, которая подсчитывает число вхождений элемента Е, значение ко-торого введено с клавиатуры, в списке Q. ...

Количество вхождений всех символов в строку
Видел похожую тему, но там задача была проще, так как надо было найти конкретный символ. В моем случае строка вводится пользователем....

Поиск всех вхождений шаблона в строку
Здравствуйте,хотела к вам обратиться за помощью..в файле t.txt есть строка из символов букв латинского алфавита,длиной до 100000 знаков....


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru