HDU "下沙野骆驼"ACM夏令营

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1292

HDU

Problem Description
大家都知道,杭电计算机学院为了吸引更多的学生参与到程序设计竞赛中去,从2005年秋天,开始举行月赛,并一直坚持到了现在。事实表明,这项措施的效果还是很明显的,现在坚持参加训练的学生比以前有了较大幅度的增长,整体水平也有了较大的提高。
为了更好的促进这项竞赛的发展,计算机学院又有了新的计划:准备在每年的暑假举行一个为期半个月的程序设计夏令营活动,活动的全称是“下沙野骆驼ACM夏令营”,准备邀请全球的编程高手共同训练,邀请对象当然少不了HFUT的DYGG,NIT的DGMM,ZJUT的QWDD,如果QH的LTC一定要来,我们也不会嫌弃,虽然他水平比其他人差了些,毕竟是杭州人,要给点面子的,再说,共同进步才是我们的最终目的,呵呵。
活动的安排初步定为7项内容,具体是:
1、第一天,倒时差(主要照顾欧美的选手)。
2、第二天,参观杭电校园,并在参观结束举行有奖竞答,偷偷透露一下,题目我已经设计好了:“杭电校院一共有几棵树?”(正确答案:3897棵),答对的营员奖励雪糕一支(不是哈根达斯,是杭州五丰生产的,民族工业还是要支持的)。
3、第三天,参观杭电ACMer的寝室,主要目的是让部分来自资本主义国家的选手看看我们是如何管理学生宿舍的,其中一项重要内容是向全球推广我校首创的“党员模范寝室”。
4、第四天,练习赛,题目只有一个:“非著名高校HD一共有教职工num个,分布在X个部门,假设每个部门有y1个正处级领导,y2个副处级领导,y3个付处级调研员,y4个正科级干部,y5个副科级干部,请输出HD的领导人员占教职工总数的比例,结果保留两位小数。”(告诉你,这个题目对于欧美选手来说有个陷阱,最后的结果可能大于100%!这是他们如何也想不到的:)
5、第五天~第十三天,算法交流,主要讨论如何求两个数的最小公倍数。
6、第十四天,自由组队(每队人数不限,呵呵,注意了),参加“下沙野骆驼杯”程序设计大赛,冠军将获得一匹下沙的野骆驼(我们主场不知道有没有机会...)
7、最后一天,篝火晚会,主题:“ACM,你到底爱不爱我?!”,主持人:骆驼王子和他一个普通老同学。

负责这次夏令营活动的是05级的小师弟Linle(一个打字速度很快,号称仅次于Fe(OH)2的小伙子),他很聪明,也很勤奋,现在他就在思考一个问题,如果一共来了n个同学,按照组队规则,一共会有多少种不同的组队方案呢?
 

Input
输入数据的第一行是一个整数C(1
 

Output
对于每组输入数据,请输出组队的方案数目,每个测试实例占一行。
 

Sample Input
 
   
3 1 2 3
 

Sample Output
 
   
1 2 5
 

Author
lcy


这是一个求递推关系的问题吧!

假设原来有n个人,m组队(q[n][m])。现在要加一个人进去(总人数为n+1),可以分为俩种情况:

1):在原来的基础上增加一组为m+1组,此时的分组方法数有q1[n+1][m+1]=q[n][m]种。

2):可以把新增的一个人,放入原来的组里面,组数还是为m组,此时的组数有q2[n+1][m]=q[n][m]*m。

所以递推关系可化为为:q[n][m]=q[n-1][m-1]+q[n-1][m]*m;


AC代码:

#include
using namespace std;
int main(){
	__int64 q[28][28]={0};
	int j,i,n;
	for(i=1;i<26;i++){
		for(j=1;j<=i;j++){
			if(j == i)
			   q[i][j]=1;
			else
			   q[i][j]=q[i-1][j-1]+q[i-1][j]*j;
		}
	}
	__int64 sum;
	int t;
	cin>>t;
	while(t--){
		sum=0;
		cin>>n;
		for(i=1;i<=n;i++)  sum+=q[n][i];
		printf("%I64d\n",sum);
	}
	return 0;
	
}

旅途中。。。。。。

你可能感兴趣的:(DP+FS)