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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ что и зачем следует, а так же как работет http://www.cyberforum.ru/cpp-beginners/thread287746.html
int askInteger() { int ret = 0; char cnt = getch(); while(cnt >= '0' && cnt <= '9') { ret *= 10; ret += cnt - '0'; cout << cnt; cnt = getch();
C++ Перегрузка оператора [][] допустим у меня есть клас Matrix и я хочу опедилить оператор доступа к его елементу как реализовть оператор если простой масив я знаю а вот если вот так нет подскажите сли кто знает http://www.cyberforum.ru/cpp-beginners/thread287743.html
C++ Моделирование перемещающего загрузчика
Здравствуйте, есть следующее задание. Первая часть: Разработать приложение по Windows 32 моделирующее работу перемещающего загрузчика. Программа считывает двоичный файл следующей структуры: N A1..AN D0 D1 … Dk-1 Dk Где: N – количество ячеек с адресами данных А1 .. АN – ячейки с адресами данных D0 .. Dk – ячейки с данными Необходимо изменить значение по адресам А1 .. АN на некоторую...
Консольный вывод расширенной ASCII и русских букв C++
Извиняюсь, если подобные темы уже есть, но с помощью поиска получить ответ на свой вопрос я не смог. Собственно, вот и он: Мне необходимо выводить на экран двумерные матрицы с русскими и/или английскими символами в рамках. Раньше для вывода русского текста использовал setlocale( LC_ALL,"Russian"); а для вывода псевдографики такую штуку static_cast<char>(n) И то, и другое - нагуглено по...
C++ Выделение текста для последующего занесение в буфер обмена http://www.cyberforum.ru/cpp-beginners/thread287669.html
Помогите пожалуйста реализовать выделение текста, уже не первый день об этом думаю и ищу и безуспешно...
C++ что означает этот синтаксис? Добрый день! в книге Бьерна Страуструпа встретил такой код enum token_valut {NAME, NUMBER, END, PLUS='+'} что значит PLUS='+' ?! подробнее

Показать сообщение отдельно
kjahert
49 / 49 / 5
Регистрация: 08.04.2011
Сообщений: 124

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

03.05.2011, 13:22. Просмотров 711. Ответов 6
Метки (Все метки)

Задание найти макс элемент стека и поменять его местами с первым элементом стэка
Кто-то помочь с переменой местами макс элемента и первого
У меня заменяет первый эл-т на максимальный, а максимальный не хочет заменять на первый

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;
 }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru