2 / 2 / 2
Регистрация: 10.10.2016
Сообщений: 142
1

Удалить из списка элемент, стоящий после элемента на который указывает пользователь

27.12.2016, 23:21. Показов 2035. Ответов 5
Метки нет (Все метки)

Нужно удалить из списка элемент, стоящий после элемента на который указывает пользователь, подскажите пожалуйста, как это сделать
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
 #include "stdafx.h"
#include <iostream>
#include <stdlib.h>
#include <conio.h>
#include <list>
 
using namespace std;
 
 
struct link
{
    int data;
    link* next;
};
 
link* first = NULL;
 
void additem(int d) // добавление элементов список
{
    link* newlink = new link;
    newlink->data = d;
    newlink->next = first;
    first = newlink;
}
 
void display() // вывод на экран
{
    link* current = first;
    while (current)
    {
        cout << current->data << endl;
        current = current->next;
    }
}
 
int main()
{
    additem(13);
    additem(12);
    additem(11);
    additem(10);
    additem(9);
    additem(8);
    additem(7);
    additem(6);
    display();
    
    system("pause");
}
Добавлено через 22 часа 8 минут
выручайте, на завтра срочно надо!

Добавлено через 4 часа 10 минут
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.12.2016, 23:21
Ответы с готовыми решениями:

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

Вставить после каждого нулевого элемента массива элемент, стоящий посередине
Добрый вечер форму. Я у вас тут новенький,и это моя первая тема:) Не знаю куда обратиться поэтому...

Удалить элемент, стоящий после максимального элемента массива
Работа в LibreOffice Calc, через макрос.

Удалить в списке элемент, стоящий после последнего минимального элемента
Удалить в списке элемент, стоящий после последнего минимального элемента. правила форума

5
2017 / 1616 / 489
Регистрация: 31.05.2009
Сообщений: 3,005
28.12.2016, 03:16 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void erase_after(link* current)
{
    if (current->next)
    {
        link* erasable = current->next;
        current->next = erasable->next;
        delete erasable;            
    }
}
 
link* advanced(link* current, int n)
{
    for (int i = 0; i < n && current; ++i)
        current = current->next;
    return current;
}
C++
1
2
3
4
// удаляем второй элемент
erase_after(first);
// перемещаемся к четвёртому элементу и удаляем элемент следующий за ним, т.е., пятый
erase_after(advanced(first, 3));
1
Вездепух
Эксперт CЭксперт С++
10285 / 5581 / 1524
Регистрация: 18.10.2014
Сообщений: 13,624
28.12.2016, 03:30 3
Цитата Сообщение от Apollo1222 Посмотреть сообщение
стоящий после элемента на который указывает пользователь,
Каким образом пользователь "указывает" на элемент?
0
2 / 2 / 2
Регистрация: 10.10.2016
Сообщений: 142
28.12.2016, 07:55  [ТС] 4
TheCalligrapher, Наверное с клавиатуры должен ввести элемент, вот условие задачи: Удалить из списка элемент, стоящий после элемента на который указывает Р
0
Вездепух
Эксперт CЭксперт С++
10285 / 5581 / 1524
Регистрация: 18.10.2014
Сообщений: 13,624
28.12.2016, 08:05 5
Цитата Сообщение от Apollo1222 Посмотреть сообщение
Наверное с клавиатуры должен ввести элемент
Что именно ввести? "Указать на элемент" можно разными способами. Можно ввести порядковый номер элемента от начала, как в ответе у rangerx. Можно ввести значение ключа (значение поля data). Можно еще как-то... Это имеет значение?
0
2 / 2 / 2
Регистрация: 10.10.2016
Сообщений: 142
28.12.2016, 08:15  [ТС] 6
TheCalligrapher, возможно я не до конца понял условие задачи, я не знаю как я указать на элемент, наверное с помощью "Р" (я не знаю что это такое)

Добавлено через 5 минут
TheCalligrapher, посмотрите пожалуйста на эту задачу, потому что мне через 2 часа надо ее сдать, а я так и не разобрался Построить и вывести бинарное дерево, степень всех вершин которого, кроме листьев, равна введенному числу
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.12.2016, 08:15
Помогаю со студенческими работами здесь

Удалить из массива элемент, стоящий в центре (если количество элементов в массиве чётное, то удалить средние два элемента).
Удалить из массива элемент, стоящий в центре (если количество элементов в массиве чётное, то...

Уменьшить каждое 2 значение списка на 1 и удалить конец списка после заданного элемента
Уменьшить каждое 2 значение списка на 1 и удалить конец списка после заданного элемента X. ...

Вставить после каждого нечетного элемента первого списка наибольший элемент второго списка
Сформировать два списка из N целочисленных случайных элементов (N – вводится пользователем, ...

Объявление переменной с типом, который указывает пользователь
Здравствуйте! Подскажите, пожалуйста, в C# есть возможность при объявлении переменной указать ее...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru