Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/41: Рейтинг темы: голосов - 41, средняя оценка - 4.54
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180

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

01.05.2011, 18:29. Показов 7611. Ответов 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
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. ?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.05.2011, 18:29
Ответы с готовыми решениями:

Создать динамический список, поменять местами последний и первый элементы списка, предпоследний и второй и т.д.
Всем привет. Подкиньте идею, весь мозг сломал. Задание:Создать динамический список. Поменять местами последний и первый элементы списка,...

Удалить первый и последний элемент очереди
Нужна программа которая будет удалять первый и последний элемент очереди.

Удалить первый и последний элемент из связанного списка
Всем Привет,как удалить первый и последний элементы из хеша, помогите пожалуйста !!! %linked_list = ( &quot;начало&quot; =&gt;...

5
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
02.05.2011, 03:13
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;
}
1
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
02.05.2011, 08:40  [ТС]
А как тогда весь листинг будет выглядеть
0
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
04.05.2011, 15:26  [ТС]
Помогите пожалуйста как будет весь листинг выглядеть я тут запутался

Добавлено через 18 часов 28 минут
помогите кто нибудь
0
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
20.05.2011, 09:12  [ТС]
Подскажите кто нибудь
0
 Аватар для pito211
187 / 174 / 18
Регистрация: 22.03.2010
Сообщений: 612
20.05.2011, 09:18
ты уже достал свою тему поднимать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.05.2011, 09:18
Помогаю со студенческими работами здесь

Дан целочисленный линейный массив. Удалить из него последний четный элемент
Дан целочисленный линейный массив. Удалить из него последний четный элемент. Помогите с решением! Пожалуйста!!!

Динамический двусвязный список (операции: добавить элемент после данного, удалить данный элемент …)
реализовать Динамический двусвязный список (операции: добавить элемент после данного, удалить данный элемент …). используя: class List...

Если первый и последний элемент - символ, сформировать список из первого и последнего элемента...
Только начали учить в универе Лисп, простенькие задачи со списками решать могу, но вот с таким вот сталкиваюсь впервые. Может есть у...

Строка: если в строке больше 2 цифр, то удалить первый и последний элемент строки
Дан массив, если в строке больше 2 цифр то удалить первый и последний элемент строки, иначе вставить в середину предпоследний символ.

Надо удалить n-ный элемент списка, при том, что он не первый и не последний
Есть такой код: #include&lt;iostream&gt; #include &quot;rus.h&quot; using namespace std; struct Info { int d; };


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru