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

Стэки - C++

Восстановить пароль Регистрация
 
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
02.05.2011, 21:43     Стэки #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
#include <iostream.h>
#include<conio.h>
 
struct node
{
 float num;
 node* next;
} ;
 
node* push(node* , float);
void printstack(node* );
node* pop(node*);
 
void main()
{
   float what;
   int n,i;
   node* top=0;
   cout<<"input n\n";
   cin>>n;
   cout<<endl;
 
    cout<<"input "<< n<<" values\n";
   for (i=1;i<=n;i++)
   {
     cin>>what;
     top= push(top, what);
   }
 
     //print stek
  printstack(top);
  node* u=top;
  node* tmp;
  node* max=0; 
while (1)
{
if(u->next>max)
       {
    max=u->next;
        break;}
else
    u=u->next;}
cout<<"MAX "<<max->num;  
/*while (1)
{
 if (u->next==tmp->next)  /////МЕНЯЕТ МЕСТАМИ МАКС ЭЛЕМЕНТ И ПЕРВЫЙ
 {
  tmp->num=u->num;
  u->num=max->num;
  max->num=tmp->num;
  break;}
  else
  u=u->next;}
  cout<<max->num;*/
 
  //top=push(top,tmp->num);
   cout<<endl;
   printstack(top);
getch();
  }
 
node* push(node* top, float what)
{
  node* pv=new node;
  pv->num=what;
  pv->next=top;
  return pv;
}
 
void printstack(node* top)
{
  float what;
 
  cout<<"stek:\n";
  while (top)
  {
    cout<<top->num<<" ";
    top=top->next;
  }
  cout<<endl;
 }
 
 node* pop(node* top)
 {
   node* pv=top->next;
   delete top;
   return pv;
 }
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.05.2011, 21:43     Стэки
Посмотрите здесь:

Очереди и стэки C++
Нужен пример по работе с объектами: Стэки, Дэки, Списки, Очереди C (СИ)

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
mansp
18 / 18 / 0
Регистрация: 07.11.2010
Сообщений: 136
02.05.2011, 22:11     Стэки #2
Код
while (u)
{
if(u.num>max)
        max=u.num;
u=u->next;}
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
02.05.2011, 22:18  [ТС]     Стэки #3
Спасибо
Правильно вот так:
C++
1
2
3
4
5
6
7
8
while (u)
{
if(u->num>max)
       {
    max=u->num;
        }
    u=u->next;
}
taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
03.05.2011, 09:29     Стэки #4
Цитата Сообщение от kjahert Посмотреть сообщение
Поменять местами у меня получилось макс. элемент с первым, только находит прога макс элемент неправильно
Если ты даже найти не можешь, то и поментяь тем более не можешь.

Добавлено через 29 секунд
Цитата Сообщение от kjahert Посмотреть сообщение
struct node { float num; node* next; } ;
Какое это имеет отношение к стеку?
Yandex
Объявления
03.05.2011, 09:29     Стэки
Ответ Создать тему
Опции темы

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