Цикл умножения int для понижения int
-
26-12-2019 - |
Вопрос
У меня есть следующий цикл:
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;
}
Я хотел бы знать, как это сделать:
Создать новый умноженный int y = z*4*3*2*1 Результат умножения будет в консольной линии записи:
("value for your loop is " +test.multiply(5));
value for your loop is 120
Можно ли это сделать с помощью for
цикл или я ошибаюсь?
Решение
Я думаю, вы на самом деле имеете в виду, что хотите вычислить факториал 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;
}
Другие советы
Это называется факториал:
public int Factorial(int num)
{
int factorial = 1;
for (int i = 2; i <= num; i++)
{
factorial *= i;
}
return factorial;
}
Вы также можете получить факториал рекурсивно (это базовое упражнение):
public int Factorial(int num)
{
if (num <= 1)
return 1;
return num * Factorial(num - 1);
}
Да:
public int multiply(int Z)
{
int Y = Z;
for (int i = Z; i > 0; i--)
{
Y *= i;
}
return Y;
}
Факториал с использованием лямбда-выражений:
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;
}
Не связан с StackOverflow