Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
alexeYesterday
0 / 0 / 1
Регистрация: 25.01.2014
Сообщений: 30
#1

Удаление элемента структуры

14.02.2014, 21:37. Просмотров 539. Ответов 2
Метки нет (Все метки)

Есть код. Удаляет заданный элемент структуры.
C++
1
2
3
4
5
6
7
8
9
void list_del(list_head *list, int i){
    if(list->head==NULL){printf("Список не содержит элементов.");return;}
    list_node *current = list->head;
    for (int j=0; j<i-1;j++){
        current = current->next;}
    list_node *temp = current->next;
    current->next=temp->next;
    free(temp->data);
    free(temp);}
Но есть проблема, если удалять последний элемент то в него заносится мусор. Программа завершается, подскажите пожалуйста как бы исправить данный баг.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.02.2014, 21:37
Ответы с готовыми решениями:

Удаление элемента структуры
void list_del(list_head *list, int i){ ...

Удаление элемента структуры из файла
Хочу сделать подобие телефонного справочника, чтобы были функции создания базы...

Удаление элемента структуры для правильного считывания WAV-файла
Господа, возник такой вопрос: Мне необходимо удалить элемент структуры. Это...

Помещение структуры в вектор, удаление структуры, изменение элементов структуры
Здравствуйте. Помогите разобраться с тем, как: 1 - находить элементы в...

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

2
zss
Модератор
Эксперт С++
7083 / 6618 / 4190
Регистрация: 18.12.2011
Сообщений: 17,446
Завершенные тесты: 1
14.02.2014, 21:46 #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    for (int j=0; j<i-1;j++)
    {
        if(current->next->next==NULL)//освобождение последнего
        {
           list_node *temp = current->next;
           current->next=NULL;
           free(temp->data);
           free(temp);  
           return;          
        }
        current = current->next;
    }
    list_node *temp = current->next;
    current->next=temp->next;
    free(temp->data);
    free(temp);}
0
retmas
Жарю без масла
865 / 747 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
14.02.2014, 21:47 #3
для последнего элемента в списке должно выполняться условие:
C++
1
current->next == NULL
видимо у вас это не так. хотя сложно утверждать имея лишь этот кусок кода
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.02.2014, 21:47

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

Сделать добавление элемента в массив и удаление элемента из массива используя STL
Всем привет. Помогите пожалуйста написать. Нужно использовать STL. Необходимо...

Реализация списка.Удаление хвостового элемента.Поиск элемента
Всем привет,мое задание выглядит так : В класс List&lt;T&gt; из классной работы...


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

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

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