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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Змейка движение вправо http://www.cyberforum.ru/cpp-beginners/thread676295.html
Здравствуйте,пишу игру змейку дошёл до того чтобы когда дошёл до конца массива перешёл на 0-ой столбец,т.е чтобы было циклично,вниз(клавиша A),и вниз(Клавиша S) я сделал но почему-то клавиша D работает только при условии что кол-во ячеек в змейке не больше 3-х если больше то вылетает таких проблем с a и s нет.Что делать помогите,вот код у клавиша D начинается с 113 строчки #include "stdio.h"...
C++ Объясните как правильно создавать проект Писать толком не умею. Было все в одном файле, надо "разбить". Когда все было в одном - работало. Объясните, пожалуйста как разбить. Main: #include <iostream> #include <sstream> #include <cmath> //#include "carray111.h" #include "CShape.h" //#include "CPoint.h" http://www.cyberforum.ru/cpp-beginners/thread676287.html
Насколько разумно использовать throw вместо return C++
Насколько разумно использовать throw вместо return? И является ли throw более медленным?
C++ Что такое "Data-driven programming"?
пожалуйста, объясните на пальцах, что такое Data-driven programming ?
C++ Построение эллипса http://www.cyberforum.ru/cpp-beginners/thread676270.html
Помогите пожалуйста, не получается нарисовать эллипс по алгоритму Брезенхэма (растровая разверстка). Рисует квадрат, почему не рисует эллипс понять не могу (Win32 Application). #include <windows.h> #include <math.h> #include<mmsystem.h> #include "stdafx.h" #include "эллипс.h" #define roundf(x) floor(x + 0.5f) #define MAX_LOADSTRING 100
C++ Переопределение тапа "class" В чём проблема? Матюкается на оба файла. #include "stdafx.h" class CData1 { public: CData1(); ~CData1(); int field1_data1; int field2_data1; подробнее

Показать сообщение отдельно
СергейАС
1 / 1 / 1
Регистрация: 02.02.2012
Сообщений: 73

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

21.10.2012, 11:39. Просмотров 369. Ответов 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;
}
Заранее спасибо!!!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:35. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru