Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
blooder21
0 / 0 / 0
Регистрация: 12.10.2013
Сообщений: 10
#1

Удаление элемента в списке - C++

14.09.2014, 21:50. Просмотров 520. Ответов 3
Метки нет (Все метки)

Описать функцию, которая удаляет из списка все вхождения элемента Е, значение которого введено с клавиатуры.
это само задание.
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
//#include "stdio.h"
#include <locale.h>
#include <iostream>
//#include <stdlib.h>
 
using namespace std;
 
 
struct LIST
{
    int Object;
    struct LIST *Next;
    struct LIST *Prev;
};
 
LIST *in=NULL;
 
LIST *Ladd(LIST *Item, int Object)
{
    LIST *NewItem = new LIST;
    NewItem->Object = Object;
    NewItem->Next = Item;
    return NewItem;
}
 
void Del(LIST **Item)
{
 
}
 
LIST *vvod(LIST *Item)
{   
    int n;
    cin >> n;
    for(int i=0;i<n;i++)
    {
        int k;
        cin >> k;
        Item=Ladd(Item,k);
    }
    return Item;
}
 
void show(LIST *Item)
{
    if (Item != NULL) 
    {
    LIST *NewItem = Item;
    while (NewItem!=NULL)
    {
        cout << NewItem -> Object << endl;
        NewItem=NewItem -> Next;
    }
    }
}
 
void main()
{
    setlocale(0,"RUS"); 
    cout <<"";
    in=vvod(in);
    Del(&in);
    show(in);
}
Добавлено через 1 минуту
Не могу понять, как же все таки удалять эти элементы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.09.2014, 21:50
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Удаление элемента в списке (C++):

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

Удаление элемента в списке - C++
Необходимо реализовать метод удаления элемента из списка не после определённого элемента (как сделано в коде), а по индексу этого элемента ...

Добавление и удаление элемента в списке - C++
Ребят сделал код создания элементов списка, но не могу написать 1) код добавления элемента списка в конец списка 2) код удаления...

В программе не работает 1)удаление элемента, последнего в списке-зависает и - C++
В программе не работает 1)удаление элемента, последнего в списке-зависает и нужна операция обработки -обмен местами элементов с заданными...

Как можно сместить ID в односвязном списке после удаление элемента - C++
народ можете подсказать как можно сместить айди в односвязном списке послу удаление элемента, на пример у меня там были айди 1, 2, 3, 4 ...

Вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск заданного элемента - C++
Добавить в класс &quot;Односвязный список&quot; следующие функции: вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск...

3
mss307
118 / 118 / 25
Регистрация: 14.12.2013
Сообщений: 352
15.09.2014, 10:11 #2
Для начала было бы неплохо использовать указатель prev, раз уж он введен.

а удаление довольно просто сделать:
1. найти нулевой элемент (для этого нужен постоянный указатель на него, либо все-таки юзать prev);
2. с нулевого элемента передвигаться по указателям next до тех пор, пока next не будет NULL;
3. при нахождении нужного элемента удаляешь его и удаляешь ссылки на него в соседних элементах.
как-то так.
0
John Prick
831 / 764 / 154
Регистрация: 27.07.2012
Сообщений: 2,176
Завершенные тесты: 3
15.09.2014, 10:18 #3
Цитата Сообщение от mss307 Посмотреть сообщение
3. при нахождении нужного элемента удаляешь его и удаляешь ссылки на него в соседних элементах.
И станет не один список, а два. Чтобы список не разрушился, нужно ещё указатели соседних с удалённым элементов установить друг на друга.
0
mss307
118 / 118 / 25
Регистрация: 14.12.2013
Сообщений: 352
15.09.2014, 10:33 #4
Цитата Сообщение от John Prick Посмотреть сообщение
И станет не один список, а два. Чтобы список не разрушился, нужно ещё указатели соседних с удалённым элементов установить друг на друга.
разумеется, я ж написал что как-то так)
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.09.2014, 10:33
Привет! Вот еще темы с ответами:

Удаление в списке - C++
Реализован метод удаления после какого-то элемента в спике: void remove(Node *where) { if (nodes&gt;1 &amp;&amp; where-&gt;next != 0) { ...

Описать класс «множество» (добавление и удаление элемента, пересечение, объединение и удаление множеств ) - C++
Описать класс «множество», позволяющий выполнять основные операции – добавление и удаление элемента, пересечение, объединение и удаление...

удаление и поиск в списке - C++
Подскажите, как реализовать функции удаления и поиска числа в списке? Нужно, что бы удаление происходило по индексу элемента, а поиск по...

Удаление элементов в списке - C++
Помогите написать программу(скорее функцию), где нужно удалить в списке элементы с позиции N по K. Список циклический однонаправленный. ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru