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

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

Войти
Регистрация
Восстановить пароль
 
scofielcl
4 / 4 / 0
Регистрация: 11.09.2011
Сообщений: 145
#1

Удаление Линейного списка - C++

15.09.2012, 22:04. Просмотров 664. Ответов 3
Метки нет (Все метки)

Доброго вечера.

Вопрос следующий : Полностью ли я освободил память выделенную под ЛС следующей функцией.

В функцию передается первый элемент списка.
C++
1
2
3
4
5
6
7
8
9
void del2(list *p){
    list *w= new list; 
    while(p){
      w->next = p->next; // вносим в w адрес след элемента.
      p->next = 0; // адремс на след. элемент списка удален
      delete p; // удален сам элемент
      p= w->next; // присваивам р след элемент
    }
}
И возможно ли более оптимизировать данный код?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.09.2012, 22:04
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Удаление Линейного списка (C++):

Удаление элемента из линейного однонапраленного списка. - C++
Говорят, что существует множество способов удаления из списка. Вот один из них: void los::del_el() { int key; los *q, *w, *e; ...

Удаление каждого второго элемента линейного списка - C++
нужно написать функцию удаления каждого 2 элемента списка, вот код по сути требуется только подставить функцию но вобще не получается её...

Доделать удаление элемента для линейного списка "Каталог файлов" - C++
В файловой системе каталог файлов организован как линейный список. Для каждого файла в каталоге содержатся следующие сведения: -> имя...

Привести пример реализации любого линейного списка списка с использованием лишь структур - C++
Буду благодарен, если кто-нибудь сможет привести пример реализации любого линейного списка списка с использованием лишь структур (то есть...

Написать код программы, выполняющей растяжку списка и вставку, удаление из списка и сжатие списка - C++
Люди ПОМОГИТЕ осталось совсем мало , мне нужна помощь!!! написать код программ: 1) Написать код программы, выполняющей растяжку...

Создание линейного списка - C++
Здравствуйте!!!!!! Помогите пожалуйста написать программку создание линейного спискаи распечатка линейного списка.Очен надо!!!! Заранее...

3
Psilon
Master of Orion
Эксперт .NET
5902 / 4799 / 634
Регистрация: 10.07.2011
Сообщений: 14,407
Записей в блоге: 5
Завершенные тесты: 4
15.09.2012, 22:36 #2
имхо нет смысла в этой строчке:
C++
1
p->next = 0; // адремс на след. элемент списка удален
Какая разница, 0 там или не 0 Все равно поле или есть, или нет, когда весь элемент удален, а значение-то что даст?)

Добавлено через 7 минут
Могу ошибаться, но мне кажется как-то так:
C++
1
2
3
4
5
6
7
8
void del2(list *p){
    list *w; 
    while(p){
      w = p;
      p = p->next;
      delete w;
    }
}
1
alsav22
5425 / 4820 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
16.09.2012, 00:22 #3
C++
1
2
3
4
5
6
7
8
9
10
void del2(list *p)
{
    list *w; 
    while(p)
    {
        w = p->next;
        delete p;
        p = w;
    }
}
1
Genco
15 / 15 / 0
Регистрация: 05.08.2012
Сообщений: 84
16.09.2012, 01:09 #4
А что надо то? List свой или из stl?

А то у стандартного копировать вроде можно примерно так:
C++
1
2
3
4
5
  list<int> W (p.begin(),p.end());   //конструктором
 
  w.insert(p.begin(),p.end()); //я не помню только, поддерживают ли итереаторы списка такую операцию
 
 list.clear(); //чистим список
1
16.09.2012, 01:09
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.09.2012, 01:09
Привет! Вот еще темы с ответами:

Создание линейного списка - C++
Помогите, пожалуйста, написать код для создания линейного списка. у меня есть такой вариант: #include &lt;iostream&gt; using namespace std; ...

Переворот линейного списка - C++
Построить линейный список из нескольких динамических переменных, содержащих вводимые целые числа. Если введенный список упорядочен по...

Произведение элементов линейного списка - C++
Подскажите пожалуйста произведение элементов линейного списка по такой функции считается? int fun (node *&amp;a,node *&amp;o) { node *p;...

Построение линейного самоадресуемого списка - C++
задание: Напишите программу создания линейного самоадресуемого списка из 10-и элементов. В поле данных каждого элемента списка – порядковый...


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

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

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