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

Ошибка в работе с классами - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ подскажите(целые, вещественный числа) http://www.cyberforum.ru/cpp-beginners/thread658069.html
задание было написать программу для вычисления выражения y=x/1000+2, #include <stdio.h> #include <conio.h> #include <math.h> #include <iostream> int main() { setlocale(0,"russian"); float x,y;
C++ ошибка -1#IND кто знает что это такое и как убрать? #include <iostream> #include <conio.h> #include <math.h> #include <fstream> #include <iomanip> using namespace std; double coss(double xx) { http://www.cyberforum.ru/cpp-beginners/thread658050.html
перегрузка cout, operator<< C++
Как реализовано, что можно перегрузить operator<< в потоке вывода, если нету объявления нужной функции внутри класса?
Найти сумму всех чисел от а до b кратных 13 и 5 C++
Вот что я пока что написал... Как сложить значения не знаю... выходит бурда полная... { unsigned long a,b,i; cin >> a; cin >> b; for (i=a;i<b;i++) { if (i%13==0) if (i%5==0) cout <<i; }
C++ 2 Оператор цикла с предусловием (while) и с постусловием (do while) http://www.cyberforum.ru/cpp-beginners/thread658042.html
всем привет помогите решить 2 задания или наведите на мысль
C++ Блок схема Помогите сделать блок схему к программе и с комментариями к программе(описание каждой функции) а то не очень понимаю как( #include "StdAfx.h" #include <iostream> #include <time.h> using namespace std; int main() { подробнее

Показать сообщение отдельно
Eugen-S
8 / 8 / 0
Регистрация: 06.11.2011
Сообщений: 122

Ошибка в работе с классами - C++

25.09.2012, 21:40. Просмотров 348. Ответов 2
Метки (Все метки)

День добрый. Прошу помощи в решении такой проблеммы.
Есть несколько классов и при компиляции возникает такое:

Error 4 error C2784: 'bool std::operator >(const std:air<_Ty1,_Ty2> &,const std:air<_Ty1,_Ty2> &)' : could not deduce template argument for 'const std:air<_Ty1,_Ty2> &' from 'number'


вот 3 класса:

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
123
124
125
126
127
template <class A>
    class iteratorq
    {
        A * ptr;
 
    public:
        iteratorq()
        {
            this->ptr=NULL;
        };
 
        iteratorq(const A*)
        {
        //  this->ptr=A;
        };
        iteratorq(const iteratorq&)
        {
//          this->ptr=&iteratorq->ptr;
        };
    
    iteratorq& operator=(const iteratorq&)
    {
        this->ptr=iteratorq->ptr;
    };
    bool operator==(const iteratorq&)
    {
        if(*this->ptr==*iteratorq)
            return 1;
            return 0;
    };
    bool operator!=(const iteratorq&)
    {
        if(*this->ptr!=*iteratorq)
            return 1;
            return 0;
    };
 
    iteratorq& operator++()
    {
        return this->ptr=this->ptr+1;
    };      // префиксный
 
    iteratorq operator++(int)
    {}; // постфиксный
 
    A& operator*()
    {
        return *this->ptr;
    };          // разыменование
    A* operator->()
    {
        return this->ptr;
    };          // это необязательно, но полезно
 
    };
 
template <class A>
    class SimpleArr
    {
        A *arr;
        int size;
    public:
        SimpleArr(int sz)
        {
            this->size=sz;
            arr=new A [sz];
        };
        
        int get_size()
        {
            return this->size;
        };
        A get_el(int pos)
        {
            return this->arr[pos];
        };
        void set_el(A el,int pos)
        {
            if(pos>=this->size || pos<0)
                {
                    cout<<"Данной позиции не существует."<<endl;
                    _getch();
                }
            else
                this->arr[pos-1]=el;
 
        };
        iteratorq <A> getelOptr()
        {
            return &(this->arr[0]);
        };
        iteratorq <A> getelNptr(int N)
        {
            return &(this->arr[N]);
        };
    
        bool operator > (SimpleArr<A> second)
        {
            
            if(this->size>second.get_size())
                return true;
            else
                return false;
        };
    };
    
        class number
        {
            int line;
        public:
            number()
            {
                line=rand()%10;
            };
            number(int num)
            {
                line=num;
            };
            int getl()
            {
                return line;
            };
            void setl(int el)
            {
                line=el;
            };
        };
К ним идут 2 ф-ции:

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
template <class prt>
    prt find_max(prt beg,prt end)
    {       
        prt max_el=beg;
 
        for(prt i=beg; i!=end; i++)
            if(*i>*max_el)
                max_el=i;
        return max_el;
    };
    
template <class prt>
    void print_all(prt beg,prt end)
    {
        prt cur = beg;
        while(cur!=end)
        {
            cout<<*cur<<endl;
            cur++;
        };
    };
Ну и мэйн:

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_CTYPE,"Russian");
    
    SimpleArr <number> arr(10); 
    arr.set_el(number(10), 3);
 
    iteratorq<number> beg  = arr.getelOptr();
    iteratorq<number> end  = arr.getelNptr(2);
 
    iteratorq<number> max_el = find_max< iteratorq<number> >(beg, end);
 
    return 0;
}
Не могу разобраться как быть( вроде как-то можно решить проблему..
ошибка на ф-ции файндМакс, где сравниваются разименованные значения... Очень прошу помощи. или скажите на что обратиь внимание стоит.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru