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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ структура класса сообщений бинарного протокола http://www.cyberforum.ru/cpp-beginners/thread304793.html
Доброго времени суток! Реализую на С++ работу с бинарным протоколом. Вернее, пока класс для хранения сообщений, их создания и парсинга. Каждое сообщение содержит заголовок и набор атрибутов. Загвоздка возникла в том, что набор атрибутов для каждого из типов сообщений(всего их 13) отличается, к тому же атрибуты могут быть вложенными. Всего атрибутов 18, имеющих 4 различных типа, в том...
C++ Удалить слова содержащие гласные буквы... Алгоритм вроде придумал но незнаю как записать... сначала наверно нужно создать char S; char D="eyuioa"; // массив гласных затем вводим текст и что то вроде этого... http://www.cyberforum.ru/cpp-beginners/thread304753.html
C++ Нада написать прогу методом динамического программирования, чтобы нашло сумму: 1/1! + 1/2! + 1/3!+ ... + 1/n!
У меня получилось сделать подсчет интегралов, а дальше как делать не допирает. Вот мой код: #include<stdlib.h> int F(int n); int main() { int k; int x; scanf("%d", &x); for(k=1; k<=x; k++)
Экземпляр класса C++
Как объявить экземпляр класса при конструкторе по умолчанию? Или как обойтись без него, используя в меине закрытые методы? А то у меня компилятор считывает объявление экземпляра класса как конструктора, да еще и ругается Добавлено через 2 минуты разобрался сам , спасибо)
C++ структуры !!! http://www.cyberforum.ru/cpp-beginners/thread304727.html
1. Описать структуру с именем SKLAD, которая содержит следующие поля: - Name – Название товара; - Type – единица измерения: - Quantity – количество единиц товара; - Cost – цена единицы товара. 2. Написать программу, которая использует даную структуру и исполняет следующие действия: - вводить с клавиатуры масив даных SHOP, что состоит с N переменных типа SKLAD; - Впорядковує записи по...
C++ Однонаправленный кольцевой список создать Однонаправленный кольцевой список элементов целого типа. удалить из него число введенное с клавиатуры уже неделю сижу.. завтра сдавать, а дело так и не сдвинулось( подробнее

Показать сообщение отдельно
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
25.05.2011, 19:26     Списки в обратном порядке
Помогите пожалуйста, кто-нибудь знает как добавить в конец сортированого списка все его элементы, располагая их в обратном порядке
Есть программа для работы со списком(сортированным)
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;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:09. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru