С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
СергейАС
1 / 1 / 1
Регистрация: 02.02.2012
Сообщений: 73
#1

Слияние списков - C++

21.10.2012, 11:39. Просмотров 415. Ответов 0
Метки нет (Все метки)

Помогите пожалуйста написать программу. Необходимо из элементов 3-х списков создать новый упорядоченный список(выполнить слияние списков). Ввод исходных списков я сделал, а вот как выполнить слияние не знаю.
Ввод списков:
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
#include "stdafx.h"
#include <list>
#include "iostream"
#include <stdio.h>
#include <conio.h>
#include<iostream>
#include<cmath>
 
using namespace System;
 
struct list
{
    int inf;
    list* next;
};
 
list* sp1_create();
list* sp2_create();
list* sp3_create();
list* sp4_create();
void print(list*L);
list* del(list*L);
 
int main()
{
    int n;
    list* F1;
    list* F2;
    list* F3;
    list* p;
    F1=sp1_create();
    F2=sp2_create();
    F3=sp3_create();
    Console::WriteLine(L"Полученные списки: ");
    print(F1);
    print(F2);
    print(F3);
    p=del(F1);
    p=del(F2);
    p=del(F3);
    system("Pause");
    return 0;
}
 
list* sp1_create()
{
 
   list *start,*new_link1,*new_link2,*new_link3,*end;
    int n;
    Console::WriteLine(L"Введите размер списка 1: ");
    scanf("%d",&n);
    end = start = NULL;
    for (int i = 0; i < n; i++)
    {
        new_link1 = new list();
        Console::WriteLine(L"Введите элемент списка:");
        scanf("%d",&new_link1->inf);
        if (!i)
            start = end = new_link1;
        else
        {
            end->next = new_link1;
            end = end->next;
        }
    }
     end->next = NULL;
     end = end->next;
    return start;
}
 
list* sp2_create()
{
 
   list *start,*new_link1,*new_link2,*new_link3,*end;
    int n;
    Console::WriteLine(L"Введите размер списка 2: ");
    scanf("%d",&n);
    end = start = NULL;
    for (int i = 0; i < n; i++)
    {
        new_link2 = new list();
        Console::WriteLine(L"Введите элемент списка:");
        scanf("%d",&new_link2->inf);
        if (!i)
            start = end = new_link2;
        else
        {
            end->next = new_link2;
            end = end->next;
        }
    }
     end->next = NULL;
     end = end->next;
    return start;
}
 
list* sp3_create()
{
 
   list *start,*new_link1,*new_link2,*new_link3,*end;
    int n;
    Console::WriteLine(L"Введите размер списка 3: ");
    scanf("%d",&n);
    end = start = NULL;
    for (int i = 0; i < n; i++)
    {
        new_link3 = new list();
        Console::WriteLine(L"Введите элемент списка:");
        scanf("%d",&new_link3->inf);
        if (!i)
            start = end = new_link3;
        else
        {
            end->next = new_link3;
            end = end->next;
        }
    }
     end->next = NULL;
     end = end->next;
    return start;
}
 
void print(list *L)
{ 
    for (; L; L=L->next)
    std::cout <<L->inf << ' ';
  std::cout << '\n';
 
}
list* del(list*L)
{ 
    list*p;
    for (int i=1; L; L=L->next,i++)
    {
        if(i==3)
            p=L;
    }
    return p;
}
Заранее спасибо!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.10.2012, 11:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Слияние списков (C++):

слияние списков - C++
помогите с написание программы!!! нужно написать программу которая объединяет два упорядоченных списка в один. Функция merge должна...

Троичное слияние списков - C++
Задание: даны три упорядоченных списка к примеру А В С, нужно слить их в едино(список Д). Помогите кто чем сможет(код, отрезок кода,...

Слияние двух списков(срочно!) - C++
Даны два списка, нужно их склеить. Вот, написал, но при комплияции выдаются неведомые мне ошибки. Кто-нибудь из опытных людей может мне...

Слияние двух отсортированных списков - C++
Напишите функцию List&amp; merge(List&amp; L1, List&amp; L2), добавляю- щую к упорядоченному списку L1 также упорядоченный список L2 и ...

Списки: реализовать слияние трёх списков в один - C++
Подскажите пожалуйста, как реализовать слияние трёх списков в один.

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

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.10.2012, 11:39
Привет! Вот еще темы с ответами:

Бинарное слияние - C++
Не получается реализовать алгоритм. Хелп плз. http://img246.imageshack.us/img246/6600/binslimf5.jpg Вот что у меня получается. ...

Слияние массивов - C++
Задан массив A из N элементов и массив B из M элементов. Сформировать массив L из массивов A и B путем их слияния так, чтобы сначала...

Слияние деревьев - C++
Сижу, мучаюсь, не могу понять что подразумевается в задании о слиянии деревьев. Подвесить вершину второго дерева к какому-нить листу 1-го?...

Слияние массивов на с++ - C++
Добродень всем.задача такая:массив структур размера N(в моем случае 100).разбить на ленты.т.о получается 10 лент по 10 элементов в каждой...


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

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

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