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

как тут эту программу через два класса сделать ? - C++

Восстановить пароль Регистрация
 
Верони4е4ка
 Аватар для Верони4е4ка
0 / 0 / 0
Регистрация: 09.02.2013
Сообщений: 42
08.06.2013, 13:58     как тут эту программу через два класса сделать ? #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
#include <iostream>
#include <cstdlib>
#include <conio.h>
 
using namespace std;
 
class Stack {
private: int foo;
public: int x;
    Stack *Next, *Head; 
 
    void Add(int x, Stack **In_data)
    {
        Stack *temp = new Stack;
        temp->x=rand ()%101-50;  
 
        temp->x = x;
        temp->Next = (*In_data)->Head
 
        (*In_data)->Head = temp; 
    };
 
    void ClearStack(Stack *In_data) 
       {
        while (In_data->Head != NULL) 
        {
            Stack *temp = In_data->Head->Next;
            delete In_data->Head; 
            In_data->Head = temp; 
        };
    }
 
};
 
void Chan(Stack *In_data, Stack *Out_data) 
{   int min=51, max=-51, k=0
    Stack *temp = new Stack; 
    temp = In_data->Head; 
    while (temp != NULL)
    {
        if (temp->x >= 0) {
            Out_data->Add(temp->x, &Out_data);
        }
        temp = temp->Next; 
    }
}
 
int main() {
    Stack *In_data = new Stack; 
    In_data->Head = NULL; 
    Stack *Out_data = new Stack; 
    Out_data->Head = NULL;
    int x = 0;
    int count = 0;
    cout << "count="; cin >> count; cout << endl;
    cout << "Stek:" << endl;
    for (int i = 0; i < count; i++) {
        cin >> x;
        In_data->Add(x, &In_data);
    }
    /*In_data->*/Chan(In_data, Out_data);
    cout << "Out stack" << endl;
    Stack *temp = new Stack; 
    temp = Out_data->Head; 
    while (temp != NULL) 
    {
        cout << temp->x << " ";
        temp = temp->Next;
    }
    void ClearStack(Stack * In_data);.
    void ClearStack(Stack * Out_data);
    getch()
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11841 / 6820 / 771
Регистрация: 27.09.2012
Сообщений: 16,911
Записей в блоге: 2
Завершенные тесты: 1
08.06.2013, 14:09     как тут эту программу через два класса сделать ? #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
#ifndef _Stack_H_
#define _Stack_H_
#include <cstddef>
namespace MTL{
template<typename T>
class Stack{//Первый
private:
    template<typename Ty>
    struct Stack_Node{//Второй
        Ty data;
        Stack_Node * next;
        Stack_Node(const Ty & _data,const Stack_Node * _next):data((Ty)_data),next((Stack_Node*)_next){}
    };
    Stack_Node<T> * topnode;
    size_t count;
public:
    Stack();
    Stack(Stack&);
    ~Stack();
    T & top() const;
    void pop();
    void push(const T & _val);
    bool empty() const;
    bool nonempty() const;
    size_t size() const;
};
 
 
template<typename T>
Stack<T>::Stack():topnode(nullptr),count(0){
}
 
template<typename T>
Stack<T>::Stack(Stack & cpy):topnode(nullptr),count(cpy.count){
    Stack_Node<T> * tempcpy=cpy.topnode;
    Stack_Node<T> * temp=nullptr;
    if(!count){
        return;
    }
    temp=topnode=new Stack_Node<T>(cpy.top(),nullptr);
    tempcpy=tempcpy->next;
    while(tempcpy){
        temp->next=new Stack_Node<T>(tempcpy->data,nullptr);
        temp=temp->next;
        tempcpy=tempcpy->next;
    }
}
 
template<typename T>
Stack<T>::~Stack(){
    Stack_Node<T> * temp=topnode;
    while(topnode){
        topnode=topnode->next;
        delete temp;
        temp=topnode;
    }
}
 
template<typename T>
bool Stack<T>::empty()const{
    return !count;
}
 
template<typename T>
bool Stack<T>::nonempty()const{
    return (bool)count;
}
 
template<typename T>
void Stack<T>::push(const T & _val){
    topnode=new Stack_Node<T>(_val,topnode);
    ++count;
}
template<typename T>
void Stack<T>::pop(){
    if (!topnode){
        // STACK пуст
        return;
    }
    Stack_Node<T> * temp=topnode;
    topnode=topnode->next;
    delete temp;
    --count;
}
template<typename T>
T & Stack<T>::top()const{
    return topnode->data;
}
 
template<typename T>
size_t Stack<T>::size()const{
    return count;
}
 
}//END MTL
#endif //END _Stack_H_
Верони4е4ка
 Аватар для Верони4е4ка
0 / 0 / 0
Регистрация: 09.02.2013
Сообщений: 42
08.06.2013, 14:22  [ТС]     как тут эту программу через два класса сделать ? #3
Croessmah, спасибо )
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11841 / 6820 / 771
Регистрация: 27.09.2012
Сообщений: 16,911
Записей в блоге: 2
Завершенные тесты: 1
08.06.2013, 14:24     как тут эту программу через два класса сделать ? #4
Цитата Сообщение от Верони4е4ка Посмотреть сообщение
Croessmah, спасибо )
Код написан давно и может не правильно, так что проверьте
Yandex
Объявления
08.06.2013, 14:24     как тут эту программу через два класса сделать ?
Ответ Создать тему
Опции темы

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