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

Создать динамический список. Удалить из него первый и последний элемент. - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 26, средняя оценка - 4.69
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
01.05.2011, 18:29     Создать динамический список. Удалить из него первый и последний элемент. #1
Список. есть пример программы:
Создать динамический список. Удалить из него первый и последний элемент.
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
#include <iostream.h>
//структура динамического списка
struct LIST
{
    int dann;
    LIST *next;
};
LIST *head=NULL;
LIST *rear=NULL;
 
//функция формирования списка
void make(int a)
{
    LIST *ptr;
    ptr=new LIST;
    if(!head) head=ptr;
    else rear->next=ptr;
    ptr->dann=a;
    rear=ptr;
    rear->next=NULL;
}
 
//функция вывода на экран элементов списка
void print(void)
{
    LIST *ptr=head;
    while (ptr) 
    {
        cout<<ptr->dann<<" ";
        ptr=ptr->next;
    }
    cout<<endl;
}
 
//функция удаления первого элемента
void deletenhead(void)
{//указатель ptr устанавливаем на первый элемент 
    LIST *ptr=head;
    //указатель head устанавливает на второй элемент
    head=ptr->next;
    //первый элемент удаляем
    delete ptr;
}
 
//функция удаления последнего элемента
void deletenrear(void)
{
    //указатель ptr устанавливаем на начало списка 
    LIST *ptr=head;
    //Если в списке один элемент
    if (ptr==rear)  
    {
        //то его удаляем
        delete ptr;
        //указатели rear и head обнуляем
        head=rear=NULL;
    }
    //Если в списке 2 и более элементов
    else 
    {
    //указатель ptr устанавливаем на предпоследний элемент
    while (ptr->next!=rear) ptr=ptr->next;
    //последний элемент удаляем
    delete rear;
    // Теперь последний элемент - это тот,
    //на который указывает ptr
    rear=ptr;
    //у последнего элемента поле next содержит NULL
    rear->next=NULL;
    }
}
 
void main (void)
{
    int n, i, b;
    cout<<"Введите количество элементов списка: ";
    cin>>n;
    cout<<"Введите  элементы списка: "<<endl;
    for(i=0; i<n; i++)
    { cin>>b;
    make(b);}
    cout<<"Введенный список: ";
    print();
    deletenhead();
    cout<<"Список после удаления первого элемента: ";
    print();
    deletenrear();
    cout<<"Список после удаления последнего элемента: ";
    print();
}
Как на основе его изменить что бы Создать динамический список. Добавить в конец списка L1 все элементы списка L2. ?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.05.2011, 18:29     Создать динамический список. Удалить из него первый и последний элемент.
Посмотрите здесь:

C++ Надо удалить n-ный элемент списка, при том, что он не первый и не последний
Динамический двусвязный список (операции: добавить элемент после данного, удалить данный элемент …) C++
Удалить первый и последний элемент очереди C++
Однонаправленный список, где создать указатель на первый элемент? C++
Сформировать двунаправленный список. Удалить из него элемент с заданным ключом, добавить элемент с указанным номером C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Vladimir.
155 / 155 / 10
Регистрация: 24.11.2009
Сообщений: 375
02.05.2011, 03:13     Создать динамический список. Удалить из него первый и последний элемент. #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
LIST* compare(LIST* list1,const LIST* list2){
if (list1!=NULL){ //первый список не пуст.
   //идем к последнему узлу первого списка:
   LIST* ptr = list1;
   while(ptr->rear != NULL) ptr = ptr->rear;
   //объединяем списки в один:
   ptr->rear = list2;
}
else list1 = list2;
 
return list1;
}
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
02.05.2011, 08:40  [ТС]     Создать динамический список. Удалить из него первый и последний элемент. #3
А как тогда весь листинг будет выглядеть
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
04.05.2011, 15:26  [ТС]     Создать динамический список. Удалить из него первый и последний элемент. #4
Помогите пожалуйста как будет весь листинг выглядеть я тут запутался

Добавлено через 18 часов 28 минут
помогите кто нибудь
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
20.05.2011, 09:12  [ТС]     Создать динамический список. Удалить из него первый и последний элемент. #5
Подскажите кто нибудь
pito211
 Аватар для pito211
186 / 173 / 8
Регистрация: 22.03.2010
Сообщений: 612
20.05.2011, 09:18     Создать динамический список. Удалить из него первый и последний элемент. #6
ты уже достал свою тему поднимать
Yandex
Объявления
20.05.2011, 09:18     Создать динамический список. Удалить из него первый и последний элемент.
Ответ Создать тему
Опции темы

Текущее время: 16:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru