Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
joemcjoe
0 / 0 / 0
Регистрация: 09.11.2013
Сообщений: 26
1

Перегрузка операторов сравнения

26.05.2014, 22:18. Просмотров 830. Ответов 4
Метки нет (Все метки)

Вот этот класс. Помогите пожалуйста.
Кликните здесь для просмотра всего текста
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
#include <iostream>
    #include<iomanip>
    #include<cstring>
    using namespace std;
     
    class HugeInt
    {
            friend ostream &operator<<( ostream &, const HugeInt & );
            friend istream &operator>>( istream &, HugeInt & );
    private:
            int num[40];
    public:
            HugeInt( long =0 );
            HugeInt( const char * );
          
            HugeInt operator-=( HugeInt & );
    };
     
     
     
    HugeInt::HugeInt( long integer )
    {
            for ( int i=0;i<40;i++ )
                    num[i]=0;
            for ( int j=39; integer!=0 && j>=0; j-- )
            {
                    num[j]=integer%10;
                    integer/=10;
            }
    }
     
     
     
    HugeInt::HugeInt( const char *sentence )
    {
            for ( int i=0;i<40;i++ )
                    num[i]=0;
            int length=strlen( sentence );
            for ( int j=40-length,k=0;j<40;j++,k++ )
            {
                    if ( isdigit(sentence[k]) )
                            num[j]=sentence[k]-'0';
            }
    }
     
     
     
     
     
     
     
     
     
     
     
     
     
     
    HugeInt HugeInt::operator-=(  HugeInt &obj )  
    {
            HugeInt temp=*this;
            HugeInt resulttemp;
            int upMinus=0;
            for( int i=39;i>=0;i-- )
            {
                    resulttemp.num[i]= num[i] - obj.num[i] + upMinus;
                    if( resulttemp.num[i]<0 )
                    {
                            resulttemp.num[i]%=10;
                            temp.num[i]=-1*resulttemp.num[i];
                            upMinus=-1;
                    }
                    else
                    {
                            temp.num[i]=resulttemp.num[i];
                            upMinus=0;
                    }
            }
            *this=temp;
            return *this;
    }
     
     
     
     
    
     
     
     
    ostream &operator<<( ostream &output, const HugeInt &obj )
    {      
            int i=0;
            for (  i=0;(obj.num[i]==0)&&(i<40);i++ )
                    ;
            if ( i==40 )
                    output<<0;
            else
            {
                    for (;i<40;i++)
     
                            output<<obj.num[i];
     
            }
     
            return output;
     
    }
     
     
     
    istream &operator>> ( istream & input, HugeInt & obj )
     
    {
     
     
     
            char temp[40];
     
     
     
            input>>temp;
     
            obj=temp;
     
     
     
            return input;
     
     
     
    }
     
    int main()
     
    {
     
            HugeInt a,b;
            cin >> a;
            cin>>b;
           
            if (a > b)
                    cout << "Greater" << endl;
            else
                    cout << "Less" << endl;
     
            if (a < b)
                    cout << "Less" << endl;
            else
                    cout << "Greater" << endl;
            a-=b;
            cout << a << endl;
     
     
            return 0;
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.05.2014, 22:18
Ответы с готовыми решениями:

Перегрузка операторов сравнения
Всем здравствуйте. У меня не выходит перегрузка операторов сравнения для собственного тд, пытаюсь...

Перегрузка операторов сравнения
Бинарное дерево BTree состоит из узлов BTreeItem. В узлах может находиться одна из фигур...

Перегрузка операторов сравнения для класса Rational
Прохожу курс вот условие Еще одна важная группа операторов, которые полезно реализовать для класса...

Перегрузка операторов сравнения и разницы. Класс String
Всем привет. задание написано в начале программы. Кто может помочь с исправлением -, &lt;, &gt; Мне...

Что такое "перегрузка операторов"? Каковы принципы работы перегруженных операторов и назначение указателя this
Добрый день . Помогите понять принцип работы перегрузки операторов. объясните пожалуйста в...

4
Tulosba
:)
Эксперт С++
4749 / 3243 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
26.05.2014, 22:31 2
Цитата Сообщение от joemcjoe Посмотреть сообщение
Помогите пожалуйста.
С чем?
0
joemcjoe
0 / 0 / 0
Регистрация: 09.11.2013
Сообщений: 26
27.05.2014, 00:17  [ТС] 3
Вот была примерно реализация. И она вроде неверная.
C++
1
2
3
4
5
bool HugeInt:: operator>=( HugeInt& obj) const
{
return true;
 
}
Выходит, всегда оно возвращает true. В чем смысл тогда?
0
Tulosba
:)
Эксперт С++
4749 / 3243 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
27.05.2014, 07:36 4
joemcjoe, вероятно это была заглушка, просто чтобы проверить собираемость кода. В конечом итоге надо заменить правильной логикой.
0
SatanaXIII
Супер-модератор
Эксперт С++
5773 / 2772 / 376
Регистрация: 01.11.2011
Сообщений: 6,744
Завершенные тесты: 1
27.05.2014, 09:33 5
Пыщь:
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
    #include <iostream>
    #include<iomanip>
    #include<cstring>
    using namespace std;
 
    class HugeInt
    {
            friend ostream &operator<<( ostream &, const HugeInt & );
            friend istream &operator>>( istream &, HugeInt & );
    private:
            #define HugeSize 40
            int num[HugeSize];
    public:
            HugeInt( long =0 );
            HugeInt( const char * );
 
            HugeInt operator -= ( HugeInt & );
            bool    operator >= ( HugeInt& obj ) const;
    };
 
    bool HugeInt:: operator>=( HugeInt& obj ) const
    {
        for( unsigned count=0; count<HugeSize; count++ )
            if( this->num[count] < obj.num[count] )
                return false;
        return true;
    }
 
    HugeInt::HugeInt( long integer )
    {
            for ( int i=0;i<40;i++ )
                    num[i]=0;
            for ( int j=39; integer!=0 && j>=0; j-- )
            {
                    num[j]=integer%10;
                    integer/=10;
            }
    }
 
    HugeInt::HugeInt( const char *sentence )
    {
            for ( int i=0;i<40;i++ )
                    num[i]=0;
            int length=strlen( sentence );
            for ( int j=40-length,k=0;j<40;j++,k++ )
            {
                    if ( isdigit(sentence[k]) )
                            num[j]=sentence[k]-'0';
            }
    }
 
    HugeInt HugeInt::operator-=(  HugeInt &obj )  
    {
            HugeInt temp=*this;
            HugeInt resulttemp;
            int upMinus=0;
            for( int i=39;i>=0;i-- )
            {
                    resulttemp.num[i]= num[i] - obj.num[i] + upMinus;
                    if( resulttemp.num[i]<0 )
                    {
                            resulttemp.num[i]%=10;
                            temp.num[i]=-1*resulttemp.num[i];
                            upMinus=-1;
                    }
                    else
                    {
                            temp.num[i]=resulttemp.num[i];
                            upMinus=0;
                    }
            }
            *this=temp;
            return *this;
    }
 
    ostream &operator<<( ostream &output, const HugeInt &obj )
    {      
            int i=0;
            for (  i=0;(obj.num[i]==0)&&(i<40);i++ )
                    ;
            if ( i==40 )
                    output<<0;
            else
            {
                    for (;i<40;i++)
                            output<<obj.num[i];
            }
            return output;
    }
 
    istream &operator>> ( istream & input, HugeInt & obj )
    {
            char temp[40];
            input>>temp;
            obj=temp;
            return input;
    }
 
    int main()
    {
 
            HugeInt a,b;
            cin >> a;
            cin >> b;
 
            if (a >= b)
                    cout << "Greater" << endl;
            else
                    cout << "Less" << endl;
 
            /*if (a < b)
                    cout << "Less" << endl;
            else
                    cout << "Greater" << endl;*/
            a-=b;
            cout << a << endl;
     
            cin.ignore(2);
            return 0;
    }
0
27.05.2014, 09:33
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.05.2014, 09:33

Перегрузка оператора сравнения
Перегрузка: bool Zakaz::operator==(Zakaz&amp;B) { if(strcmp(Familia_Zak,B.Familia_Zak)==0 &amp;&amp; Street...

Перегрузка оператора сравнения
Посмотрите, пжл, правилен ли синтаксис перегрузки оператора сравнения для двух строк: #include...

Перегрузка оператора сравнения
Скажите, как перегрузить оператор сравнения == и другие? попробовал bool operator == (char* A,char*...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru