description
給定乙個函式 f(a, b, c):
如果 a ≤ 0 或 b ≤ 0 或 c ≤ 0 返回值為 1;
如果 a > 20 或 b > 20 或 c > 20 返回值為 f(20, 20, 20);
如果 a < b 並且 b < c 返回 f(a, b, c−1) + f(a, b−1, c−1) − f(a, b−1, c);
其它情況返回 f(a−1, b, c) + f(a−1, b−1, c) + f(a−1, b, c−1) − f(a-1, b-1, c-1)。
看起來簡單的乙個函式?你能做對嗎?
input
輸入包含多組測試資料,對於每組測試資料:
輸入只有一行為 3 個整數a, b, c(a, b, c < 30)。
output
對於每組測試資料,輸出函式的計算結果。
sample input
1 1 1sample output2 2 2
2hint4
題意:就是按照題目要求
分析:容易超時,可以用記憶搜尋
**:
感受:這個題原來做過,但是這次做比原來錯的多了,因為大意,感覺自己會了,就沒有太注意細節。。。。#includeusing namespace std;
long long int x[30][30][30]=;
long int vp(int a,int b,int c)
{ if(x[a][b][c]==0)
{if(a==0||b==0||c==0)
x[a][b][c]=1;
else
if(a>20||b>20||c>20)
x[a][b][c]=vp(20,20,20);
else
if(a>a>>b>>c)
{if(a<=0||b<=0||c<=0)
cout<
遞推遞迴 C 遞迴的函式
題目 description 給定乙個函式 f a,b,c 如果 a 0 或 b 0 或 c 0 返回值為 1 如果 a 20 或 b 20 或 c 20 返回值為 f 20,20,20 如果 a b 並且 b c 返回 f a,b,c 1 f a,b 1,c 1 f a,b 1,c 其它情況返回 ...
C 遞迴的函式
submit status description 給定乙個函式 f a,b,c 如果 a 0 或 b 0 或 c 0 返回值為 1 如果 a 20 或 b 20 或 c 20 返回值為 f 20,20,20 如果 a b 並且 b c 返回 f a,b,c 1 f a,b 1,c 1 f a,b ...
C 遞迴的函式
description 給定乙個函式 f a,b,c 如果 a 0 或 b 0 或 c 0 返回值為 1 如果 a 20 或 b 20 或 c 20 返回值為 f 20,20,20 如果 a b 並且 b c 返回 f a,b,c 1 f a,b 1,c 1 f a,b 1,c 其它情況返回 f a...