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

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

Войти
Регистрация
Восстановить пароль
 
kjahert
49 / 49 / 5
Регистрация: 08.04.2011
Сообщений: 124
#1

Списки в обратном порядке - C++

25.05.2011, 19:26. Просмотров 411. Ответов 4
Метки нет (Все метки)

Помогите пожалуйста, кто-нибудь знает как добавить в конец сортированого списка все его элементы, располагая их в обратном порядке
Есть программа для работы со списком(сортированным)
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
#include <iostream.h>
 
struct node
{
 int num;
 node *next;
};
 
node* toList(node* ,int);
node* fromList(node*, int );
void printList(node*);
 
void main()
{
 int what,i,n;
 node *head=0;
 
 cout<<"input n=";
 cin>>n;
 cout<<endl;
 
 
 cout<<"input all what"<<endl;
 for (i=1;i<=n;i++)
 {
   cin>>what;
   head= toList(head ,what);
  }
 
 printList(head);
 
 cout<<"InputWhatFromList:"<<endl;
 cin>>what;
 head=fromList(head,what);
 
 printList(head);
 }
 
node* toList(node* head ,int num)
{
 node* pv=new node;
 
 pv->num=num;
 pv->next=0;
 if (head)
 {
    node* cur=0;
   if(head->num> pv->num)
   {
     pv->next=head;
     head=pv;
   }
   else
   {
     cur=head;
     while((cur->next) && (cur->next->num < pv->num))
    cur=cur->next;
     pv->next=cur->next;
     cur->next=pv;
    }
  }
 else
   head=pv;
 return head;
 }
 
 
node* fromList(node* head, int num)
{
   int  prdel;
   node* erased=0;
   node* cur=0;
   node* buf=new node;
   buf->num=num;
   buf->next=0;
   if (( head->num) == (buf->num))
   {
      erased=head;
      head=head->next;
      delete erased;
   }
   else
   {
    cur=head;
    erased=cur->next;
    prdel=0;
    do
     {
      if ( buf->num==erased->num)
    {
     cur->next=erased->next;
     delete erased;
     prdel=1;
    }
      else
    {
      cur=erased;
      erased=cur->next;
    }
     }
 
    while  ((prdel==0) ||(erased != 0));
 }
 return head;
}
 
void printList(node* pv)
{
  if (!pv)
    cout<<"List is nil\n";
  else
    while(pv)
   {
     cout<<"="<<pv->num<<endl;
     pv=pv->next;
    }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.05.2011, 19:26     Списки в обратном порядке
Посмотрите здесь:

C++ в обратном порядке
корень в обратном порядке C++
решить (массив в обратном порядке)! C++
C++ В обратном порядке
Вывести строку в обратном порядке. C++
Вывод в обратном порядке C++
C++ Вывести в обратном порядке
Слово в обратном порядке C++
Вывести слова в обратном порядке C++
Перестановка строк в обратном порядке C++
Копировать в обратном порядке C++
C++ Число в обратном порядке

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
kjahert
49 / 49 / 5
Регистрация: 08.04.2011
Сообщений: 124
27.05.2011, 17:25  [ТС]     Списки в обратном порядке #2
Никто не знает?
Nameless One
Эксперт С++
5765 / 3414 / 255
Регистрация: 08.02.2010
Сообщений: 7,433
27.05.2011, 17:35     Списки в обратном порядке #3
Самое простое - рекурсия/стек.
kjahert
49 / 49 / 5
Регистрация: 08.04.2011
Сообщений: 124
29.05.2011, 17:36  [ТС]     Списки в обратном порядке #4
У нас за прАстоэ па попе дают, а тут индивидуальное задание, где только списки(рекурсия/стек кагбэ прошли)

Добавлено через 2 часа 15 минут
Неужели все так не любят списки(сортированные)?

Добавлено через 13 минут
Видно не подходящее время ( воскресенье ) для таких вопросов (сорт. списки)
kjahert
49 / 49 / 5
Регистрация: 08.04.2011
Сообщений: 124
02.06.2011, 20:26  [ТС]     Списки в обратном порядке #5
Хоть кто-то знает?
Yandex
Объявления
02.06.2011, 20:26     Списки в обратном порядке
Ответ Создать тему
Опции темы

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