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

нулевые элементы - C++

Восстановить пароль Регистрация
 
Gothic Angelos
 Аватар для Gothic Angelos
1 / 1 / 0
Регистрация: 29.05.2010
Сообщений: 140
22.05.2011, 01:26     нулевые элементы #1
Программа удаляет нулевые элементы в сортированном списке....Функция fromList удаляет за раз только 1 элемент.
Как сделать чтоб сразу все нули удаляла?
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
#include <iostream.h>
#include<conio.h>
struct node
{
 int num;
 node *next;
};
 
node* toList(node*  ,int );
node* fromList(node*, int );
void printList(node*);
 
void main()
{
clrscr();
 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;
 cout<<"HOBbIU CnUCOK:"<<endl;
 
 head=fromList(head,what);
 
 
 getch();
 }
 
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=1;
    do
     {
      if ( (buf->num)==(erased->num))
    {
     cur->next=erased->next;
     delete erased;
     prdel=0;
    }
      else
    {
      cur=erased;
      erased=cur->next;
    }
     }
 
    while  ((prdel!=0) || (erased != 0));
  }
 printList(head);
 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
22.05.2011, 01:26     нулевые элементы
Посмотрите здесь:

C++ Нулевые элементы в начало
одномерный массив. Все его элементы, не равные нулю, переписать, сохраняя их порядок в начало массива, а нулевые элементы в конец массива in c++ C++
Все отрицательные элементы массива уменьшить в двое, а все нулевые элементы заменить на... C++
Заменить первые два нулевые элементы заданного вектора В на два первых НЕ нулевые элементы этого вектора C++
C++ Нулевые элементы
C++ Заменить первых 2 нулевые элементы заданного вектора соответственно на первых 2 не нулевые элементы этого вектора
Создать два новых массива, в один из которых поместить положительные элементы массива, а в другой отрицательные и нулевые элементы C++
C++ Перенести в начало массива нулевые элементы

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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