Polimorfismo por Anulacion (DUDA)
Publicado por Salvador (1 intervención) el 23/05/2016 22:28:10
En este programa se muestra la ecuacion de segundo grado en polimorfismo por sobrecarga me urge saber como pasarlo a polimorfismo por ANULACION. Gracias
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
#include<iostream>
#include<stdlib.h>
#include<math.h>
using namespace std;
class primero
{
protected:
float a;
public:
void entrada()
{
do
{
system("cls");
cout<<"Introduce el valor de a: "<<endl;
cin>>a;
}while(a==0);
};
};
class segundo
{
protected:
float b;
public:
void entrada()
{
cout<<"Intruduce el valor de b"<<endl;
cin>>b;
};
};
class tercero
{
friend class opera;
protected:
float c;
public:
void entrada()
{
cout<<"Intruduce el valor de c"<<endl;
cin>>c;
};
};
class opera:public primero,public segundo,public tercero
{
protected:
float x1,x2,des,r,d,r1,r2;
public:
void entrada()
{
des=(b*b)-(4*a*c);
if(des>0)
{
r=sqrt(des);
x1=(-(b)+r)/(2*a);
x2=(-(b)-r)/(2*a);
cout<<"El valor de x1="<<x1<<endl;
cout<<"El valor de x2="<<x2<<endl;
}
if(des==0)
{
x1= -(b)/(2*a);
x2= x1;
cout<<"El valor de x1="<<x1<<endl;
cout<<"El valor de x2="<<x2<<endl;
}
if(des<0)
{
d=-1*des;
r=(sqrt(d)/(2*a));
r1=(-(b)/(2*a));
r2=(-(b)/(2*a));
cout<<"El valor de x1="<<r1<<"+"<<r<<"i"<<endl;
cout<<"El valor de x2="<<r2<<"-"<<r<<"i"<<endl;
}
};
};
int main ()
{
char resp;
do
{
system("cls");
opera e;
e.primero::entrada();
e.segundo::entrada();
e.tercero::entrada();
e.entrada();
do
{
cin.ignore();
cout<<endl<<endl<<"Continuar (S/N): ";
cin>>resp;
resp=toupper(resp);
} while(resp!='S' && resp!='N');
}while(resp=='S');
}
Valora esta pregunta
0