C/Visual C - FACTORIAL

 
Vista:

FACTORIAL

Publicado por xiomaraitz (4 intervenciones) el 20/02/2008 02:28:07
ALGUIEN ME PUEDE AYUDAR NO TENGO IDEA COMO HACER ESTE PROGRAMA Q TIENE Q CALCULAR EL FACTORIAL DE UN NUMERO INTRODUCIDO X EL USUARIO.. SI ALGUIEN SABE ME PODRIA AYUDAR....!!!!!!!!!!!!
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

RE:FACTORIAL

Publicado por nayumi orama (53 intervenciones) el 20/02/2008 12:14:50
El factorial es el ejemplo de programación recursiva por antonomasia.

Se trata de que hagas una funcion que se llame a sí misma, multiplicando el valor que recibe por la llamada a la misma funcion restandole una unidad al parámetro recibido. La funcion terminará cuando el valor recibido llegue a 1.

en pseudocódigo

funcion factorial ( valor )
{
si ( valor es mayor que 1 )
{
return valor * factorial(valor-1)
}
si no
return valor
}
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:FACTORIAL

Publicado por nayumi orama (53 intervenciones) el 21/02/2008 09:07:40
Venga vale, ....

Tu solución no es que esté mejor, ¡¡¡¡ es que se la has dado hecha!!!!

Yo siempre procuro enseñar a pescar en vez de dar los peces.

En fin.....
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:FACTORIAL

Publicado por fernando.gomez (1603 intervenciones) el 21/02/2008 21:47:15
:O jejeje, era broma. De hecho, sí, está dada, pero también es lo suficientemente complicada. Como diría Sutter, ¿para qué hacer algo fácil cuando se puede hacer complicado?

Mmm... creí que entenderían la broma :-(

jejeje, en fin. Saludos.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:FACTORIAL

Publicado por fernando.gomez (1603 intervenciones) el 20/02/2008 23:41:03
Aquí tienes tu programa completo. Puedes cambiar el "int" por "long" si vas a calcular números grandes, o inclusive crear tus propias clases (siempre y cuando sobrecargues los operadores necesarios). Creo que el código es claro y fácil de comprender. Deberías apreciarlo ya que me llevó una media hora escribirlo, solo para tí, y hasta empleando buenas técnicas y patrones de diseño. Solo no puse mucha atención en las validaciones como overflows y eso.

Saludos.

#include <cstddef>
#include <iostream>

using namespace std;

template<typename T, class TFunctor>
class Factorial
{
public:
Factorial() : _t() { }
Factorial(const Factorial& fact) : _t(fact._t) { }
Factorial(const T& t) : _t(t) { }
virtual ~Factorial() { }

T Calc()
{
T t;
TFunctor func;
t = func(_t);
return t;
}

T Calc(TFunctor func)
{
T t;
t = func(_t);
return t;
}

Factorial& operator= (const Factorial& fact)
{
_t = fact._t;
return *this;
}

Factorial& operator= (const T& t)
{
_t = t;
return *this;
}

private:
T _t;
};

template<typename T, class TEstrategia, class TUnit>
class CalcFactorial : public TEstrategia
{
public:
CalcFactorial() { }
virtual ~CalcFactorial() { }

T operator()(const T& tval)
{
T tres;
TEstrategia* estrategia;

estrategia = static_cast<TEstrategia*>(this);
tres = (*estrategia)(tval);

return tres;
}

};

template<typename T, T TUnit>
class EstrategiaRecursiva
{
public:
EstrategiaRecursiva() { }
virtual ~EstrategiaRecursiva() { }

T operator()(const T& tval)
{
T taux;
T tres;

taux = static_cast<T>(tval);
if (taux == _tunit)
tres = _tunit;
else
tres = taux * (*this)(taux - _tunit);

return tres;
}

private:
static const T _tunit = TUnit;
};

template<typename T, T TUnit>
class EstrategiaDirecta
{
public:
EstrategiaDirecta() { }
virtual ~EstrategiaDirecta() { }

T operator()(const T& tval)
{
T taux;
T tres;

taux = static_cast<T>(tval);
tres = _tunit;

for (T t = _tunit; t <= tval; t += _tunit)
{
tres *= t;
}

return tres;
}

private:
static const T _tunit = TUnit;
};

int main()
{
Factorial<int, EstrategiaRecursiva<int, 1> > factorial;
char cmd;
int num;
int res;

cmd = 0;
num = 0;
res = 0;

do
{
cout << "Indique el número a calcular o escriba '0' para salir." << endl;
cin >> num;
if (num > 0)
{
cout << "Indique la estrategia a utilizar: " << endl;
cout << " R - Recursiva" << endl;
cout << " D - Directa" << endl;
cin >> cmd;

if (cmd == 'R')
{
Factorial<int, EstrategiaRecursiva<int, 1> > factorial;
factorial = num;
res = factorial.Calc();
cout << "El factorial de " << num << " empleando la estrategia recursiva es " << res << endl;
}
else if (cmd == 'D')
{
Factorial<int, EstrategiaDirecta<int, 1> > factorial;
factorial = num;
res = factorial.Calc();
cout << "El factorial de " << num << " empleando la estrategia directa es " << res << endl;
}
else
{
cout << "Opción inválida." << endl;
}

cout << " " << endl;
}
} while (num > 0);

return 0;
}
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar