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

перегрузка оператора! - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Домино http://www.cyberforum.ru/cpp-beginners/thread558339.html
нужна программа домино исходник для курсака
C++ Поменять в словах первую букву на маленькую дана строка символов состоящая из произвольного текста слова разделены пробелами.в каждом слове поменять первую букву на прописную. помогите пожалуйста прога оч нужна. http://www.cyberforum.ru/cpp-beginners/thread558337.html
Очистить текстовый файл C++
есть функция сохранения в файл.. int out_file(char* filename,date* cor) { fstream file(filename); file.open(filename); while (cor) { file<<cor->kol_kom; file<<cor->floor; file<<cor->plo;
C++ парсер строки
Народ, помогите, плиз! проблема такая : сперва считываю строку из файла string value; getline (file, value, '\n'); теперь в value хранится : "ФИО String; Дата_рождения Date; Кол-во Integer; Рейтинг Float" далее имею 2 массива строк string *name и string *type как в них записать значения из строки value ?
C++ set_intersection ??? не понятная ошибка. http://www.cyberforum.ru/cpp-beginners/thread558286.html
есть базовый класс car, производный Bus. Так же есть класс который не связан с Bus и car, он называется Park. Park является frind class для car. Проблема: // Автопарк #define max_nbuses 100 class Park { string name;//название парка int dohod;// ежегодный доход int nbus; public: vector <Bus> Buss; ...
C++ Каков будет порядок элементов списка[6, 2, 4, 7, 1, 3, 8, 5] после построения пирамиды Каков будет порядок элементов списка после построения пирамиды подробнее

Показать сообщение отдельно
sanchez.1
2 / 2 / 0
Регистрация: 01.11.2011
Сообщений: 8
25.04.2012, 16:04     перегрузка оператора!
Помогите сложить диагонали , при помоши перегрузки оператора+, чтобы можно было написать в maine: c1+c2+c3.заранее спасибо!
C++ (Qt)
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
#include<iostream>
#include<math.h>
using namespace std;
 
class Taskas
{
    
private:
double x;
double y;
public:
    Taskas( ): x(0.), y(0.) { } 
    Taskas(double xx, double yy ): x(xx), y(yy) {}
 ~Taskas( ) { } 
void ivest(char c) {
    cout<<"VVedite "<<c<< "  Koordinaty versny:"<<endl;
    cin>>x>>y;}
void rodyti(char c) {cout<<c<< " Koordinaty versny: "<<x<<" "<<y<<endl;}
double gaukX() {return x;}
double gaukY() {return y;}
};
class staciakampis
{
    
private:
    Taskas a,b,c,d;
    double kr1,kr2,kr3,kr4;
    double istr;
public:
        staciakampis( ): a( 0.,0. ), b( 0.,0. ), c( 0.,0. ), d(0.,0.) { }  
 staciakampis( double ax, double ay,                     
                  double bx, double by, 
                  double cx, double cy,
                  double dx, double dy):  
a( ax, ay ), b( bx, by ),c( cx, cy ),d(dx,dy) { }  
 ~staciakampis( ) { } 
 
 void rastiTaskus(){
     
         cout<<"VVedite koordinaty:"<<endl;
 a.ivest('A');
 b.ivest('B');
 c.ivest('C');
 d.ivest('D');
     } 
 void rodytiTaskus(){
 cout<<"Koordinaty:"<<endl;
 a.rodyti('A');
 b.rodyti('B');
 c.rodyti('C');
 d.rodyti('D');
 }
 void tikrinimas(){
 
 if(a.gaukX()==b.gaukX()){
            kr1=a.gaukY()-b.gaukY();
            kr3=c.gaukY()-d.gaukY();
        }
        else if(a.gaukX()==c.gaukX()){
        
        kr1=a.gaukY()-c.gaukY();
        kr3=b.gaukY()-d.gaukY();
                }
        else if(a.gaukX()==d.gaukX()){
            kr1=a.gaukY()-d.gaukY();
            kr3=b.gaukY()-c.gaukY();
        }
        else{
        cout<<"eto ne priamougolnik!"<<endl;
        exit(-1);
        }
        if(a.gaukY()==b.gaukY()){
            kr2=a.gaukX()-b.gaukX();
            kr4=c.gaukX()-d.gaukX();
        }
        else if(a.gaukY()==c.gaukY()){
        
        kr2=a.gaukX()-c.gaukX();
        kr4=b.gaukX()-d.gaukX();
        
        }
        else if(a.gaukY()==d.gaukY()){
 kr2=a.gaukX()-d.gaukX();
 kr4=b.gaukX()-c.gaukX();
        }
        else{
            cout<<"eto ne priamougolnik!"<<endl;
        exit(-1);
        }
        if(kr1!=kr3 && kr2!=kr4){
        cout<<"eto ne priamougolnik!"<<endl;
        exit(-1);
        }
 }
    void istrizaine(){
        
    double d=(kr1*kr1+kr2*kr2);
   istr=sqrt(d);
   cout<<"Dlina diagonali: "<<istr<<endl;
    }
    double rD(){
    return istr;
    }
    
    void maxd(staciakampis &c1,staciakampis &c2,staciakampis &c3){
double xmas[3]={c1.rD(),c2.rD(),c3.rD()};
double gg;
double maxD=0;
for(int i=0;i<3;i++){
    if(xmas[i]>maxD){
        maxD=xmas[i];
    gg=i;
    }
    }
gg++;
cout<< endl<<gg<<"-o staciakampio istrizaine didziausia - "<<maxD<<endl;
    }};
 
 
int main()
{
staciakampis c1(0,1,0,4,3,1,3,4),c2,c3;
c1.tikrinimas();
c1.rodytiTaskus();
c1.istrizaine();
 
c2.rastiTaskus();
c2.tikrinimas();
c2.rodytiTaskus();
c2.istrizaine();
 
c3.rastiTaskus();
c3.tikrinimas();
c3.rodytiTaskus();
c3.istrizaine();
 
c1.maxd(c1,c2,c3);
return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru