标签:动态 20 OJ 递归 int SDUT return include 21
- 熟悉掌握动态规划类型的解法
动态规划的要点是需要找出 “状态转移方程”
A——递归的函数
#include <stdio.h>
#include <stdlib.h>
int d[21][21][21]={0};
int f(int a,int b,int c)
{
if(a<=0||b<=0||c<=0)
return 1;
if(a>20||b>20||c>20)
return f(20,20,20);
if(d[a][b][c])
{return d[a][b][c];
}
else if(a<b&&b<c)
return d[a][b][c]=f(a,b,c-1)+f(a,b-1,c-1)-f(a,b-1,c);
else
return d[a][b][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);
}
int main()
{
int a,b,c;
int k;
while(~scanf("%d%d%d",&a,&b,&c))
{k=f(a,b,c);
printf("%d\n",k);
}
return 0;
}
标签:动态,20,OJ,递归,int,SDUT,return,include,21 来源: https://blog.csdn.net/wjt_1025/article/details/89526082
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。