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

Стек элементы не меняются местами - C++

Восстановить пароль Регистрация
 
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
03.05.2011, 13:22     Стек элементы не меняются местами #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
#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* tmp1;
  node* tmp2;
  node* max;
   
while (u)
{
if(u->num>max->num)
       {
        max->num=u->num;
        tmp1->num=max->num;
        }
    else
 
    if (u->next->next==0)
    {
     tmp=u->next;
         tmp2->num=tmp->num;
     tmp->num=tmp1->num;
     max->num=tmp2->num;
    //}
     //else
     //if (max>u->num)
     //{
          //u->num=max;
     //u->num=tmp->num;
    //}
    //else
        //if (
     //u->num=max->num;
     //max->num=tmp->num;
    break;}
    else
    u=u->next;}
 
 
//cout<<u->num;
/*while (top)
{
 if (top->next==tmp->next)
 {
  tmp->num=top->num;
  //top->num=max->num;
  //max->num=tmp->num;
  break;}
  else
  top=top->next;}
  cout<<tmp->num;*/
/* while (1)
 {
  if (top->next==max->next)
  {
   top->next=tmp->next;
   break;}
   else
   u=u->next;
  }*/ 
  //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
03.05.2011, 13:22     Стек элементы не меняются местами
Посмотрите здесь:

C++ почему не меняются элементы класса c++?
Поменять местами первый и последний элементы. Все единичные элементы массива заменить нулями C++
C++ Строки. Считывание текста и его вывод, в котором каждые 2 соседних слова меняются местами
с++ стек (не удаляются элементы) C++
C++ Вывести элементы массива в виде таблицы и переставить его элементы местами
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ValeryLaptev
Эксперт C++
1005 / 784 / 46
Регистрация: 30.04.2011
Сообщений: 1,595
03.05.2011, 14:03     Стек элементы не меняются местами #2
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
#include <iostream.h>     // -- по стандарту <iostream>
#include<conio.h>
 
struct node
{
 float num;
 node* next;
} ;
 
node* push(node* , float);
void printstack(node* );
node* pop(node*);
 
void main()                               // -- по стандарту int main()
{
   float what;
   int n,i;
   node* top=0;
   cout<<"input n\n";   cin>>n;
   cout<<endl;
 
   cout<<"input "<< n<<" values\n";
  // -- лучше - от 0
   for (i=0; i<n; i++)
   {
     cin>>what;
     top= push(top, what);
   }
 
     //print stek
  printstack(top);
// --  node* u=top;
  node* tmp;
  node* tmp1;
  node* tmp2;
  
 
   node* u = top;
   node* max = top;                         // -- это надо тоже инициализировать перед циклом 
while (u)
{
   if(u->num > max->num)
   {    // -- max->num = u->num;       // -- нужен только указатель на максимальный элемент
        // -- tmp1->num=max->num;     // -- обменивать будем после цикла --
        max = u;
   }
/* -- это все не нужно --
   -- надо просто перейти к следующему --   
else    
    if (u->next->next==0)
        {
         tmp=u->next;
         tmp2->num=tmp->num;
         tmp->num=tmp1->num;
         max->num=tmp2->num;
        //}
         //else
         //if (max>u->num)
         //{
          //u->num=max;
         //u->num=tmp->num;
        //}
        //else
        //if (
         //u->num=max->num;
         //max->num=tmp->num;
        break;}
        else
*/
        u=u->next;
}
// -- вот здесь имеем top и max
// -- осталось обменять - надеюсь, сможешь сам... :)
 
 
   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;
 }
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
03.05.2011, 14:19  [ТС]     Стек элементы не меняются местами #3
Я вообщет думал, что первый элемент это тот который вводиш первым а не тот кот. отображает стек после ввода:
ввел 4 7 3
выдало 3 7 4
Так какой первый эл-т 3 или 4?

Добавлено через 1 минуту
Если 3 то так намного легче канешн, я пытался поменять 4(последний) на максимальный
ValeryLaptev
Эксперт C++
1005 / 784 / 46
Регистрация: 30.04.2011
Сообщений: 1,595
03.05.2011, 14:31     Стек элементы не меняются местами #4
Я понял так, что первый - который на вершине (на него указывает top). Если понимать первый как первый введенный, то в списке он последний (то есть, на самом дне стека). Это тоже легко найти, причем в том же цикле...
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
03.05.2011, 14:34  [ТС]     Стек элементы не меняются местами #5
Верю что легко но незнаю как
ValeryLaptev
Эксперт C++
1005 / 784 / 46
Регистрация: 30.04.2011
Сообщений: 1,595
03.05.2011, 14:38     Стек элементы не меняются местами #6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
  
  node* max = top;     
  node* u = top->next;
  node* prev = top;
while (u)
{
   if(u->num > max->num)
   {    // -- max->num = u->num;       // -- нужен только указатель на максимальный элемент
        // -- tmp1->num=max->num;     // -- обменивать будем после цикла --
        max = u;
   }
   prev = u;   
   u=u->next;
}
После цикла имеешь:
max - указатель на максимальный элемент
prev - указатель на нижний элемент стека
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.05.2011, 14:49     Стек элементы не меняются местами
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
kjahert
48 / 48 / 5
Регистрация: 08.04.2011
Сообщений: 124
03.05.2011, 14:49  [ТС]     Стек элементы не меняются местами #7
Спасибо большое
Yandex
Объявления
03.05.2011, 14:49     Стек элементы не меняются местами
Ответ Создать тему
Опции темы

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