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

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

Войти
Регистрация
Восстановить пароль
 
gunslinger17
0 / 0 / 0
Регистрация: 25.02.2012
Сообщений: 80
#1

Написать процедуру присоединения списка к другому списку - C++

12.05.2012, 18:39. Просмотров 495. Ответов 0
Метки нет (Все метки)

Задача: Написать процедуру присоединения списка L2 к списку L1.
Код:
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <ctype.h>
struct stack{int chislo; stack *next;};
stack *begin=NULL;
stack *create(void)
{
      stack *t; 
      t=new stack; 
      scanf("%d",t->chislo); 
      t->next=NULL; 
      return t;
}
stack *add(stack *x, int c)
{
      stack *t; 
      t=new stack;
      t->chislo=c;
      //scanf("%d",t->chislo); 
      t->next=x; 
      return t;
}
stack *delet(stack *x)
{
      if(x==NULL){printf("Пустой"); return x;} 
      else {stack *t; x->next; printf("%d",x->chislo); delete x; return t;}
}
int main(){
int c;
stack *p,*L1,*L2;
scanf("%d", c);
begin=create();
begin=add(begin,c);
begin=add(begin,c);
begin=delet(begin);
begin=delet(begin);
p=begin;
while(p)
{
printf("%d",p->chislo);
p=p->next;
}
...
getch();
return 0;
}
Ошибка: программа запускается, но ничего не отображает и отключается после нажатия на любую клавишу.

Добавлено через 5 часов 25 минут
Подправил. Но как-то это надо все попроще сделать.
И все равно не так как надо работает: в конец списка l1 прикрепляется только один элемент из l2, причем первый.
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <iostream.h>
 
struct stack{int chislo; stack *next;};
 
stack *l1=NULL,*l2=NULL;
stack *create(void)
{
      stack *t;
      t=new stack;
      scanf("%d",&t->chislo); 
      t->next=NULL;
      return t;
}
 
stack *add(stack *x)
{
      stack *t;
      t=new stack;
      scanf("%d",&t->chislo); 
      t->next=x;
      return t;
}
 
 
stack *copy(stack *x, int c)
{
      stack *t;
      t=new stack;
      t->chislo=c;
      t->next=x;
      return t;
}
 
stack *ffu(stack *x)
{
      stack *t;
      t=x->next;
      return t;
}
 
stack *delet(stack *x)
{
      if(x==NULL){printf("Empty"); return x;} 
      else {stack *t; x->next; printf("\n%d",x->chislo); delete x; return t;}
}
 
int main()
{
l1=create();
l1=copy(l1,1);
l1=copy(l1,1);
l2=create();
l2=copy(l1,2);
stack *y=l2;
l2=y;
l2=ffu(l2);
l1=copy(l1,l2->chislo);
l2=y;
l1=copy(l1,l2->chislo);
 
stack *x=l1;
l1=x;
l1=ffu(l1);
l1=ffu(l1);
l1=ffu(l1);
l1=ffu(l1);
l1=delet(l1);
l1=x;
l1=ffu(l1);
l1=ffu(l1);
l1=ffu(l1);
l1=delet(l1);
l1=x;
l1=ffu(l1);
l1=ffu(l1);
l1=delet(l1);
l1=x;
l1=ffu(l1);
l1=delet(l1);
l1=x;
l1=delet(l1);
getch();
return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.05.2012, 18:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Написать процедуру присоединения списка к другому списку (C++):

Написать функцию присоединения стека S2 к стеку S1 - C++
Написать функцию присоединения стека S2 к стеку S1.

Написать процедуру удаления из заданного списка, все вхождения элемента с заданным значением - C++
Написать программу, процедуру удаления из заданного списка, все вхождения элемента с заданным значением.

Написать код программы, выполняющей растяжку списка и вставку, удаление из списка и сжатие списка - C++
Люди ПОМОГИТЕ осталось совсем мало , мне нужна помощь!!! написать код программ: 1) Написать код программы, выполняющей растяжку...

Как можно по-другому написать эту программу - C++
#include &lt;iostream&gt; using namespace std; void swap(int x, int y,int &amp;x1,int &amp;y1) { int dop; dop = x; x1 = y; y1 = dop; ...

Как по-другому написать заданный фрагмент кода? - C++
for(; num ;num/=10) // как по другому написать это строку на C++?

Написать функцию, которая из списка образует два новых списка. Один содержит нечетные числа, а второй - парные - C++
Помогите закончить одно из заданий по работе со списком: Написать функцию, которая использует первоначальный список L и образует два...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.05.2012, 18:39
Привет! Вот еще темы с ответами:

Разработать процедуру удаления из списка первого отрицательного элемента - C++
Задача: Разработать процедуру удаления, из списка L, первого отрицательного элемента.

Описать процедуру или функцию, которая находит max элемент не пустого списка L - C++
Задание: описать процедуру или функцию, которая находит max элемент не пустого списка L (инф. часть списка содержит real) P.S.: Помогите...

Почему допустимо создавать объект по другому объекту, но нельзя присваивать уже созданный объект, другому созданному объекту? - C++
Это можно : Array a(10); a.set(0,5); Array b(a); А это нельзя : Array a(10); Array b(20); a = b;

Написать процедуру разворачивания стека - C++
Уважаемые форумчане, Нужны решения к нижеприведенным заданиям. Желательно с подробными комментариями. Заранее благодарен. 2....


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

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

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