Problema ejercicio de class - CONSULTA

Iniciado por Cero++, 13 Diciembre 2018, 22:39 PM

0 Miembros y 1 Visitante están viendo este tema.

Cero++

Buenas, acá les dejo el código que hice ya comentado con mis dudas, a ver si me pueden dar un poco de iluminación que no estoy entendiendo  :-\
PD: el método sumar, me pide que lo haga de este modo:
Código (cpp) [Seleccionar]
P_resuesta=P1.Sumar(P2)[/b]

Código (cpp) [Seleccionar]
#include <iostream>
#include <cmath>
using namespace std;
class Polinomio{
int coeficiente[20]; int grado;
public:
Polinomio(int _grado=0){
grado=_grado;
for(int i=0;i<grado;i++) {
coeficiente[i]=0;
}
};
int Ver_coeficientes(int _i){
return coeficiente[_i];
}
void Cambiar_coeficiente(int _c, int _pos);
Polinomio Sumar_polinomios(Polinomio p2);
int Evaluar(int _x);


};
void Polinomio::Cambiar_coeficiente(int _c, int _pos){
coeficiente[_pos]=_c;
}
Polinomio Polinomio:: Sumar_polinomios(Polinomio p2){
for(int i=0;i<grado;i++) {
coeficiente[i]+=p2.Ver_coeficientes(i); //Que deberia retornar?
}
}
int Polinomio::Evaluar(int _x){
int aux=0;
for(int i=0;i<grado--;i++) {
aux+=coeficiente[i]*(pow(_x,(grado-i)));
}
aux+=coeficiente[grado];
return aux;
}
int main(int argc, char *argv[]) {
int size; int coeficiente;
cout<<"Ingrese el grado del Polinomio: "; cin>>size;
Polinomio P(size);
/*Carga del polinomio*/
cout<<"Ingrese los coeficientes, de mayor grado a menor "; cin>>coeficiente;
int i=0;
while(i<size){
P.Cambiar_coeficiente(coeficiente,i);
cout<<"Ingrese los coeficientes, de mayor grado a menor "; cin>>coeficiente;
++i;
}
/*Veamos la carga inicial*/
for(int i=0;i<size;i++) {
cout<<P.Ver_coeficientes(i)<<"x^"<<size-i; //Por que no veo el termino independiente?
}
cout<<endl;
/*Evaluemos con un valor x el polinomio*/
int x;
cout<<"Ingrese la incognita: "; cin>>x;
cout<<P.Evaluar(x); //Obtengo basura, por que?
cout<<endl;
/*Probemos el metodo sumar Polinomio*/
/* nada*/

Ser diligente es lo ÚNICO que importa para lograr el éxito[c/ode]

K-YreX

Hay varios problemas:
- Cuando indicas grado 3, tienes que meter los coeficientes {0,1,2,3}, es decir, 4 coeficientes.
Código (cpp) [Seleccionar]

for(int i = 0; i < 3; i++)

Ese bucle se repite 3 veces, no 4. Te faltaría añadir el igual en la comparación, es decir, "i <= 3".
- Cuando introduces coeficientes, introduces el primero y lo guardas. Pero el <while> va en el siguiente orden: primero cambias coeficiente, después pides coeficiente. Entonces el último que ingreses no se va a guardar.
- En el método de sumar tienes que crear un polinomio nuevo de tamaño igual al mayor de los dos polinomios que sumas. En tu método, modificas el primero y la suma solo se hace hasta el grado más alto del primer polinomio, si el segundo es mayor, se pierden esos coeficientes. Debes retornar el nuevo polinomio que has creado que es donde has ido almacenando la suma.

No he mirado más código. Personalmente creo que es mejor guardarlo al revés. En la posición 0, el coeficiente de grado 0, en la posición 1, el coeficiente de grado 1, etc... Es más fácil de imaginar y si quieres añadir un grado más grande, puedes hacerlo sin mover todos los elementos que ya tienes dentro.
Para mostrar un polinomio añade el signo si el coeficiente es negativo, nada y si es positivo añade un "+". Es muy complicado ver bien el polinomio cuando se muestra, si de momento no quieres gastar tiempo en eso añade al menos un espacio entre monomios. Suerte :-X
Código (cpp) [Seleccionar]

cout << "Todos tenemos un defecto, un error en nuestro código" << endl;

Cero++

Cita de: YreX-DwX en 13 Diciembre 2018, 23:10 PM
Es muy complicado ver bien el polinomio cuando se muestra, si de momento no quieres gastar tiempo en eso añade al menos un espacio entre monomios. Suerte :-X

Buenas, ya pude arreglar casi todo, los únicos métodos que no funcionan son estos, te paso el código además:

Código (cpp) [Seleccionar]
//C)
Polinomio Sumar_polinomio(Polinomio P2){ //Asi es como me decias que tenia que hacerlo?
if(P2.grado<grado){
Polinomio aux(grado);
for(int i=0;i<P2.grado;i++) {
aux.monomio[i]=P2.monomio[i]+monomio[i];
}
for(int i=P2.grado;i<grado;i++) {
aux.monomio[i]=monomio[i];
}
return aux;
}else{
Polinomio aux(P2.grado);
for(int i=0;i<grado;i++) {
aux.monomio[i]=P2.monomio[i]+monomio[i];
}
for(int i=grado;i<P2.grado;i++) {
aux.monomio[i]=monomio[i];
}
return aux;
}

}
//D)
int Evaluar_polinomio(int _x){
int contador=0;
for(int i=0;i<=grado;i++) {
contador+=(monomio[i])*(pow(_x,i)); //El resultado que obtengo siempre es 1 menos que el verdadero
}
return contador;
}
Ser diligente es lo ÚNICO que importa para lograr el éxito[c/ode]