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

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

Войти
Регистрация
Восстановить пароль
 
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
#1

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

08.09.2009, 12:58. Просмотров 526. Ответов 5
Метки нет (Все метки)

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); посмотрите в чом дело
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.09.2009, 12:58
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Поиск звена с элементом el в списке, заданном указателем phead (C++):

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

В чем разница между указателем и указателем на указатель? - C++
int x, *p, *q; x=10; p=&amp;x; q=p; cout&lt;&lt;*q; int x, *p, **q; x=10; p=&amp;x; q=&amp;p;

В заданном массиве найти элемент, расположенный между первым нулевым и максимальным элементом - C++
Из элементов массива А из n элементов, расположенных между первым нулевым и максимальным (в предположении, что в массиве есть положительные...

Построение моделей апериодического звена, реального дифференцирующего звена, колебательного звена - Simulink
Здравствуйте помогите построить в simulink модель апериодического звена, реального дифференцирующего звена,колебательного звена

Создать список случайных чисел в заданном интервале не содержащийся в заданном списке - Python
Задан упорядоченный по возрастанию целочисленный массив. Сформировать второй массив из случайных целых чисел, которые не встречаются в...

Поменять местами первый и последний узел в односвязном циклическом списке с указателем на хвост - Turbo Pascal
Здравствуйте! Нужно написать процедуру, которая меняет местами первый и последний узел в односвязном циклическом списке с указателем...

5
kravam
быдлокодер
1697 / 884 / 45
Регистрация: 04.06.2008
Сообщений: 5,484
08.09.2009, 13:21 #2
Попробуй так работать.
C++
1
Spisok::node* Spisok::POISK (int el)
0
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
08.09.2009, 13:23  [ТС] #3
большое спасибо kravam.
0
АНК
124 / 115 / 2
Регистрация: 27.02.2007
Сообщений: 291
08.09.2009, 15:03 #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();
};
и так далее
0
kravam
быдлокодер
1697 / 884 / 45
Регистрация: 04.06.2008
Сообщений: 5,484
08.09.2009, 15:51 #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 безо всяких функций-методов
Что, повторюсь, в Андрейкины планы не входило вообще, а даже наоборот.
Извините
0
АНК
124 / 115 / 2
Регистрация: 27.02.2007
Сообщений: 291
08.09.2009, 18:18 #6
kravam, верное замечание! Да, теперь тип node стал самостоятельным и его можно использовать в любом месте Unit'а. Но переменные из
класса
node *phead; //Указатель на заглавное звено списка.
node *Res;//Указатель на найденное звено списка.
все равно будут доступны только
с помощью исключительно функций-методов.
0
08.09.2009, 18:18
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.09.2009, 18:18
Привет! Вот еще темы с ответами:

Получить определенные поля класса, работая с указателем на класс, как с указателем на массив - C++ Builder
Мне бы хотелось узнать в чем ошибка моего кода Вот мои наработки которые не работают где я пытаюсь получить текст из второго поля зная...

Определить элемент списка L, следующий за элементом X в этом списке - Prolog
Определить предикат для формирования списка из элементов, вводимых с клавиатуры (элементы включаются в список в порядке их ввода, либо, при...

Какой синтаксис при сравнении элемента с любым элементом в списке? - Python
Например, есть пустой список a = я постепенно добавляю туда элементы. мне нужно задать условие, чтобы туда добавлялись только те...

Отсортировать слова в заданном списке по алфавиту - Pascal
1. Отсортировать слова в заданном списке по алфавиту. 2. Выполнить задание 1, при этом строка считывается из текстового файла. ...


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

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

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