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

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

21.12.2014, 09:28. Показов 7265. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
2 самых главных вопроса: как создать одновременно 2 списка?
как из второго списка поместить элементы в первый?
Вообще нигде не могу найти даже примера решения подобной задачи(

Постановка задачи: Даны два списка L1 и L2. Включить
после каждого элемента списка L1 с максимальным значением
последовательность элементов списка L2.

Ниже приведены функции работы со списком, и в main есть попытка создания еще одного.
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
91
92
93
94
95
96
97
98
99
100
101
#include <stdio.h>
#include <string>
#include <iostream>
#include <conio.h>
using namespace std;
using std::cout;
using std::cin;
using std::endl;
 
struct List {
    float info;
    List *pred, *next;
};
int k;
 
//функция создает новый элемент к и вставляет в список q
List *AddList(List *q, int k){
    List*p;
    p = new List;
    p->info = k;
    p->pred = q;
    p->next = q->next;
    p->next->pred = p;
    q->next = p;
    return p;
}
//функция создает двусвязный список со сторожами head,tail
void CreatList(List *&head, List *&tail) {
    List *q, *p;
    head = new List;
    tail = new List;
    head->next = tail;
    tail->pred = head;
    head->pred = tail->next = NULL;
    cout << "Вводите числа,для выхода введите 101" << endl;
    cin >> k;
    q = head;
    while (k != 101)//пока к !=101
    {
        q = AddList(q, k);
        cin >> k;
    }
    return;
};
 
//вывод списка на экран
void PrintList(List *head, List*tail){
    List *p = head->next;
    while (p != tail){
        cout << p->info << " ";
        p = p->next;
    }
    cout << endl;
    return;
};
//функция "вынимает" элемент из списка
void CutList(List *&p){
    List *a, *b;//указатели на соседей
    a = p->next;
    b = p->pred;
    a->pred = p->pred;
    b->next = p->next;
    return;
}
//функция меняет местами 2 элемента списка
void Swap(List *&p, List*&q){
    q->next = p->next;
    p->next = q->pred->next;
    p->pred = q->pred;
    q->pred = q->next->pred;
    p->next->pred = p;
    p->pred->next = p;
    q->next->pred = q;
    q->pred->next = q;
 
    return;
}
 
 
 
 
void main(){
    setlocale(LC_ALL, "Russian");
    List *head, *tail;
    List *s, *w;//сторожа
 
    CreatList(head, tail);
    cout << "исходный список" << endl;
    PrintList(head, tail);
    
    CreatList(s,w);  //вот я создала другой список. но что делать дальше, не знаю(
    cout << "2 список" << endl;
    PrintList(s, w);
 
    cout << "конечный список" << endl;
    PrintList(head, tail);
 
 
    system("pause");
    return;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.12.2014, 09:28
Ответы с готовыми решениями:

Clojure Создать два списка, поместив в первый отрицательные, а во второй – положительные элементы исходного списка
Помогите пожалуйста решить следующие задачи: 1. Задан список чисел. Создать два списка, поместив в первый отрицательные, а во второй –...

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

Функция, вставляющая в первый список элементы второго списка
примечание: Определите на двух языках Clisp и SWI-Prolog соответственно функцию и предикат для работы со списком. Все функции и предикаты...

2
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
21.12.2014, 10:41
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
#include <iostream>
 
using namespace std;
 
struct data_t
{
    int value;
    data_t() {}
    data_t(int value) : value(value) {}
    data_t(const data_t& d) : value(d.value) {}
};
 
struct node_t:public data_t
{
    node_t():
        next(nullptr), prev(nullptr) {}
    node_t(const data_t& d, node_t* n = nullptr, node_t* p = nullptr):
         data_t(d.value),next(n), prev(p) {}
    node_t* next;
    node_t* prev;
};
 
struct list_t
{
    node_t* m_head;
    node_t* m_last;
    list_t() : m_head(nullptr), m_last(nullptr) {}
    list_t(list_t&& l) : m_head(nullptr), m_last(nullptr) {
        std::swap(l.m_head, m_head);
        std::swap(l.m_last, m_last);
    }
    list_t& operator=(list_t&& l)  {
        std::swap(l.m_head, m_head);
        std::swap(l.m_last, m_last);
        return *this;
    }
    node_t* head()
    {
        return m_head;
    }
 
    /// добавление в начало
    inline void push_front(const data_t& data)
    {
        return paste_node(new node_t(data), nullptr);
    }
    /// добавление в конец списка
    inline void push_back(const data_t& data)
    {
        return paste_node(new node_t(data), m_last);
    }
    inline void reverse_print() const
    {
        return reverse_print_from(m_last);
    }
    inline void forward_print() const
    {
        return forward_print_from(m_head);
    }
 
    /// обменивает 2 элемента по индексам
    void swap_nodes(int index1, int index2)
    {
        if (index1 > index2)
        {
            int temp = index1;
            index1 = index2;
            index2 = temp;
        }
 
        if (index1 < 0 || index1 == index2)
            return;
 
        node_t* index1Node = nullptr;
        node_t* index2Node = nullptr;
 
        index1Node = get_by_idx(index1 ,m_head);
        if (index1Node == nullptr)
            return;
        index2Node = get_by_idx(index2 - index1, index1Node);
 
        if (index2Node == nullptr)
            return;
 
 
        node_t *n1p, *n1n;
        n1n = index1Node->next;
        n1p = index1Node->prev;
 
        cut_node(index1Node);
        paste_node(index1Node, index2Node);
        if(n1n != index2Node) {
            cut_node(index2Node);
            paste_node(index2Node, n1p);
        }
 
    }
    /// ищет максимальный элемент
    /// список должен быть не пуст
    data_t find_max() {
        data_t  t;
        node_t* h = m_head;
        t.value = h->value;
        while(h) {
            if(t.value < h->value)
                t.value = h->value;
            h = h->next;
        }
        return t;
    }
    /// вставляет копию списка l после элементов со значением m
    list_t& insert(const list_t& l, const data_t& m) {
        auto n = m_head;
        while(n) {
            n = find_from(n, m);
            if(n)
                n = insert_copy(l, n);
        }
        return *this;
    }
private:
    /// ищет d начиная со звена n
    node_t* find_from(node_t* n, const data_t& d) const {
        while(n) {
            if(n->value == d.value)
                break;
            n = n->next;
        }
        return n;
    }
    node_t* insert_copy(const list_t& l, node_t* n) {
        node_t* h;
        h = l.m_head;
        while(h) {
            paste_node(new node_t(h->value),n);
            n = n->next;
            h = h->next;
        }
        return n;
    }
    /// печатает список от указанного звена к началу
    void reverse_print_from(const node_t* tmp) const
    {
        while (tmp != nullptr)
        {
            cout << tmp->value << " ";
            tmp = tmp->prev;
        }
        cout << endl;
    }
    /// печатает от указанного звена до конца списка
    void forward_print_from(const node_t* tmp) const
    {
        while (tmp != nullptr)
        {
            cout << tmp->value << " ";
            tmp = tmp->next;
        }
        cout << endl;
    }
    /// вырезает указанное звено из списка
    void cut_node(node_t* n) {
        if(n == m_head) m_head = m_head->next;
        else if(n->prev) {
            n->prev->next = n->next;
        }
        if(n == m_last) m_last = m_last->prev;
        else if(n->next) {
            n->next->prev = n->prev;
        }
        n->next = nullptr;
        n->prev = nullptr;
    }
    /// вставляет звено n после x. при x == nullptr вставляет в начало
    void paste_node(node_t* n, node_t* x) {
        if (x == nullptr) {
            n->next = m_head;
            if(!m_head) {
                m_head = m_last = n;
            }
            else {
                m_head->prev = n;
                m_head = n;
            }
        }
        else {
            n->next = x->next;
            n->prev = x;
            if (x->next) x->next->prev = n;
            x->next = n;
            if (x == m_last) m_last = n;
        }
    }
    /// поиск звена по смещению от first
    static node_t* get_by_idx(int idx,
                            node_t* first) {
        int index = 0;
        while (first) {
            if (index == idx) break;
            first = first->next;
            index++;
        }
        return first;
    }
};
 
 
int main()
{
    list_t l1, l2;
 
    ///
    ///TODO: ввод элементов сделайте самостоятельно
    ///
 
    l1.insert(l2, l1.find_max()) // код вне main позволяет
                                 // свести задачу к этой строчке
            .forward_print();
    return 0;
}
0
0 / 0 / 0
Регистрация: 21.12.2014
Сообщений: 2
21.12.2014, 11:06  [ТС]
Не понимаю, что за три структуры? зачем они? Названия странные.. я же только на 1 курсе((
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.12.2014, 11:06
Помогаю со студенческими работами здесь

Разделить список на 2, в первый поместить четные элементы исходного списка, во второй - нечетные
Помогите пожалуйста, написать программу переносящую все нечетные элементы одномерного числового массива в один новый массив,а четные в...

Как определить оставшиеся элементы списка и поместить их в стэк ?
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace...

Удалить из списка все парные элементы и поместить их в конец списка в обратном порядке
Доброго времени суток, уважаемие форумчани, помогите Создать список L , элементами которого являются целые числа. Удалить из списка L...

Удалить из списка все отрицательные элементы и поместить их в конец списка в обратном порядке
Пожалуста, помогите решить задачку: Составит программу, которая создает список L елементами которего есть целые числа, удаляет из него все...

Динамические списки: при выборе элементов первого списка должны динамически формироваться элементы второго
на странице есть 2 связанных multiselect списка: при выборе элементов первого списка должны динамически формироваться элементы другого...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru