Форум программистов, компьютерный форум 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='+' ?! подробнее

Показать сообщение отдельно
ValeryLaptev
Эксперт C++
1005 / 784 / 46
Регистрация: 30.04.2011
Сообщений: 1,595
03.05.2011, 14:03     Стек элементы не меняются местами
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;
 }
 
Текущее время: 14:28. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru