Bucle multiplica int para bajar int
-
26-12-2019 - |
Pregunta
Tengo el siguiente bucle:
public int multiply(int Z)
{
//Z=5
for (int i = 1; i <= Z; i++)
{
int Y=Z*i;
return Y;
//i wanna Y multiply x*4*3*2*1 all loops in one result
}
return Z;
}
Qué me gustaría saber hacer es:
Crear un nuevo multiplicar int y= z * 4 * 3 * 2 * 1 El resultado de multiplicar sería en la línea de escritura de la consola:
("value for your loop is " +test.multiply(5));
value for your loop is 120
¿Se puede hacer esto por un bucle de for
o estoy equivocado?
Solución
Lo que creo que realmente quiere decir es que desea calcular el factorial de z.
public int Factorial(int Z)
{
if (Z < 0) then return 0;
int res = 1;
for (int Y = 1; Y <= Z; Y++)
{
res *= Y;
}
return res;
}
Otros consejos
Esto se llama factorial :
public int Factorial(int num)
{
int factorial = 1;
for (int i = 2; i <= num; i++)
{
factorial *= i;
}
return factorial;
}
También puede obtener factorial recursivamente (este es un ejercicio básico):
public int Factorial(int num)
{
if (num <= 1)
return 1;
return num * Factorial(num - 1);
}
Sí:
public int multiply(int Z)
{
int Y = Z;
for (int i = Z; i > 0; i--)
{
Y *= i;
}
return Y;
}
factorial usando lambdas:
Func<int, int> factorial = null;
factorial = x => x <= 1 ? 1 : x * factorial(x-1);
var result = factorial(10);
: -)
public int multiply(int Z)
{
int result = Z;
for (int i = 1; i <= Z; i++)
{
int Z*=i;
}
return Z;
}
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow