遞回解階乘、費氏級數
想起來以前在學c++時曾經寫過的程式與大家分享,呵。
1.階乘解法
0!=1
5! = 5 * 4 * 3 * 2 * 1
x! = x * (x - 1) * (x - 2) * (x - 3) * ..... * 1
1
private int Factor(int x)
2
{
3
if (x == 0) return 1;
4
else
5
return Factor(x - 1) * x;
6
}
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
2
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
3
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
4
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
5
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
6
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
2.費氏級數解法
f(1) = 1
f(2) = 1
f(x) = f(n - 1) + f(n - 2)
1
private int Fib(int x)
2
{
3
if (x == 1 || x == 2) return 1;
4
else
5
return Fib(x - 1) + Fib(x - 2);
6
}
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
2
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
3
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
4
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
5
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
6
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
不過工作後有前輩指出盡量少用遞回寫法聽說也許是因為耗資源的關係吧。