Loop moltiplicare int per abbassare INT
-
26-12-2019 - |
Domanda
Ho il seguente ciclo:
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;
}
.
Cosa mi piacerebbe sapere come fare è:
Crea un nuovo multiplo int y= z * 4 * 3 * 2 * 1 Il risultato di moltiplicare sarebbe in console scrittura linea:
("value for your loop is " +test.multiply(5));
value for your loop is 120
.
può essere fatto da un ciclo for
o ho sbagliato?
Soluzione
Quello che penso di significare davvero è che tu voglia calcolare il fattoriale di 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;
}
. Altri suggerimenti
Questo è chiamato fattoriale :
public int Factorial(int num)
{
int factorial = 1;
for (int i = 2; i <= num; i++)
{
factorial *= i;
}
return factorial;
}
.
Puoi anche ottenere in modo ricorsivo in modo recupero (questo è l'esercizio di base):
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;
}
. fattoriale 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;
}
. Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow