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

Поиск звена с элементом el в списке, заданном указателем phead - C++

Восстановить пароль Регистрация
 
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
08.09.2009, 12:58     Поиск звена с элементом el в списке, заданном указателем phead #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
126
127
128
129
130
131
132
133
134
#include<iostream>
using namespace std;
class Spisok
{
  private:
    struct node
    {
      int   elem;
      node *sled;
    };
    node *phead; //Указатель на заглавное звено списка.
    node *Res;//Указатель на найденное звено списка.
public:
    Spisok() {phead=new(node); (*phead).sled=NULL; Res=NULL;}
    ~Spisok() { delete phead; }
    void POSTROENIE();
    void VYVOD();
    node *POISK(int);
    void VSTAV(int);
    void VSTAV1(int)
    void OCHISTKA();
};
 
void main ()
{
  Spisok A;
  int  el,el1;
 
  A.POSTROENIE ();
  A.VYVOD ();
  cout<<"\nВведите элемент звена,после которого ";
  cout<<"осуществляется вставка:\n";
  cin>>el;
  cout<<"Введите элемент вставляемого звена:\n";
  cin>>el1;
  if  (A.POISK(el)!=NULL)
  {
    A.VSTAV (el1); A.VYVOD ();
  }
  else  cout<<"Звена с заданным элементом в списке нет!";
  cout<<"\nВведите элемент звена, перед которым  ";
  cout<<"осуществляется вставка:\n";
  cin>>el;
  cout<<" Введите элемент вставляемого звена:\n";
  cin>>el1;
  if  (A.POISK (el)!=NULL)
  {
    A.VSTAV1 (el1); A.VYVOD ();
  }
  else  cout<<" Звена с заданным элементом в списке нет!";
  A.OCHISTKA();
}
 
void Spisok::POSTROENIE ()
// Построение однонаправленного списка с заглавным звеном.
// phead - указатель на заглавное звено списка           
{
  node *t;
  int   el;
  t = phead;
  cout<<"Вводите элементы звеньев списка: ";
  cin>>el;
  while  (el!=0)
  {
    (*t).sled = new (node);
    t = (*t).sled; (*t).elem = el; (*t).sled = NULL;
    cin>>el;
  }
}
 
void Spisok::VYVOD ()
// Вывод содержимого однонаправленного списка с 
// заглавным звеном.  phead - указатель на заглавное звено списка.
{
  node *t;
 
  t =(*phead).sled;
  cout<<"Список: ";
  while  (t!=NULL)
  {
    cout<<(*t).elem<<" "; t = (*t).sled;
  }
  cout<<endl;
}
 
node *Spisok::POISK (int el)
//Поиск звена с элементом el в списке, заданном указателем 
//phead. В случае успешного поиска в Res находится адрес 
//звена списка, содержащего элемент el, в случае  неуспеха 
//в Res помещается NULL.
{
  node *t;
 
  Res = NULL; t = (*phead).sled;
  while  (t!=NULL && Res==NULL)
  if  ((*t).elem==el)
    Res = t;
  else  t = (*t).sled;
 
  return Res;
}
 
void Spisok::VSTAV (int el)
// Включение звена  с  информационным полем  el  
// после звена, на которое указывает ссылка Res.
{
  node *q;
 
  q = new(node);
  (*q).elem = el;
  (*q).sled = (*Res).sled; (*Res).sled = q;
}
 
void Spisok::VSTAV1 (int el)
// Включение звена с информационным полем el  
// перед звеном, на  которое  указывает  Res.
{
  node *q;
 
  q = new (node);
  (*q).elem = (*Res).elem; (*q).sled = (*Res).sled;
  (*Res).elem = el; (*Res).sled = q;
}
 
void Spisok::OCHISTKA ()
//Удаление однонаправленного списка из памяти.
// phead - указатель на заглавное звено списка.
{
  node *q,*q1;// Рабочие указатели.
 
  q = phead;
  q1 = (*q).sled; // Указатель q1 "опережает" указатель q.
  while (q1!=NULL)
    { q = q1; q1 = (*q1).sled; delete q;}}
ругается на node *spisok(int); посмотрите в чом дело
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.09.2009, 12:58     Поиск звена с элементом el в списке, заданном указателем phead
Посмотрите здесь:

C++ Поиск элемента в списке
C++ Поиск в лин. списке
C++ phead->nblockuse
удаление и поиск в списке C++
C++ Осуществить поиск в списке
C++ Рекурсивный поиск в списке
Поиск элемента в списке C++
Поиск в двусвязном списке C++
C++ Поиск числа в списке
C++ Поиск в двусвязном списке
Поиск в списке C++
C++ В заданном массиве найти элемент, расположенный между первым нулевым и максимальным элементом

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
kravam
быдлокодер
 Аватар для kravam
1513 / 873 / 44
Регистрация: 04.06.2008
Сообщений: 5,301
08.09.2009, 13:21     Поиск звена с элементом el в списке, заданном указателем phead #2
Попробуй так работать.
C++
1
Spisok::node* Spisok::POISK (int el)
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
08.09.2009, 13:23  [ТС]     Поиск звена с элементом el в списке, заданном указателем phead #3
большое спасибо kravam.
АНК
124 / 115 / 2
Регистрация: 27.02.2007
Сообщений: 291
08.09.2009, 15:03     Поиск звена с элементом el в списке, заданном указателем phead #4
Вынести описание структуры node из класса. Типа:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
struct node {
 int elem;
 node *sled;
};
 
class Spisok {
private:
 node *phead; //Указатель на заглавное звено списка.
 node *Res;//Указатель на найденное звено списка.
public:
 Spisok() {phead=new(node); (*phead).sled=NULL; Res=NULL;}
 ~Spisok() { delete phead; }
 void POSTROENIE();
 void VYVOD();
 node *POISK(int);
 void VSTAV(int);
 void VSTAV1(int)
 void OCHISTKA();
};
и так далее
kravam
быдлокодер
 Аватар для kravam
1513 / 873 / 44
Регистрация: 04.06.2008
Сообщений: 5,301
08.09.2009, 15:51     Поиск звена с элементом el в списке, заданном указателем phead #5
Боюсь что Анк не прав. Да, скомпилится.
Только программа станет ДРУГОЙ, не той которая задумана.
Ибо: что имел ввиду Андрейка, когда писал:
C++
1
2
3
4
5
6
 [B]private[/B]:
    struct node
    {
      int   elem;
      node *sled;
    };
?
А имел он ввиду, друзья, что бы переменные типа node изменялись бы с помощью исключительно
функций-методов.

...Теперь к коду предложенному Анк, добавим вот этот код

C++
1
2
3
4
5
6
7
8
9
10
11
#include<iostream>
using namespace std;
int main () {
 //Внимание: тип переменной
 node vot_eta_peremennaya;
 
 vot_eta_peremennaya.elem= 100;
 cout<< vot_eta_peremennaya.elem;
 getchar ();
 return 0;
}
Скомпилируем и выполним и увидим, что переменной vot_eta_peremennaya.elem присвоено значение 100 безо всяких функций-методов
Что, повторюсь, в Андрейкины планы не входило вообще, а даже наоборот.
Извините
АНК
124 / 115 / 2
Регистрация: 27.02.2007
Сообщений: 291
08.09.2009, 18:18     Поиск звена с элементом el в списке, заданном указателем phead #6
kravam, верное замечание! Да, теперь тип node стал самостоятельным и его можно использовать в любом месте Unit'а. Но переменные из
класса
node *phead; //Указатель на заглавное звено списка.
node *Res;//Указатель на найденное звено списка.
все равно будут доступны только
с помощью исключительно функций-методов.
Yandex
Объявления
08.09.2009, 18:18     Поиск звена с элементом el в списке, заданном указателем phead
Ответ Создать тему
Опции темы

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