"下沙野骆驼"ACM夏令营

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Total Submission(s): 833    Accepted Submission(s): 403

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<C<25)。表示測试实例的数目。然后是C行数据,每行一个整数n(0<n<25),表示营员的人数。

 
Output
对于每组输入数据,请输出组队的方案数目。每一个測试实例占一行。
 
Sample Input
3
1
2
3
 
Sample Output
1
2
5
 

题意:求n个人组队的全部不同方式,如3个人a,b,c,能够组成:{a,b,c},{ab,c},{ac,b},{bc,a},{abc}5种方式。

解题思路:易知2个人能够组成{a,b}{ab}2种方式;

1、添加的一人单独一队,则原来的方法数目不变,队伍数目都+1,dp[i][j]=dp[i-1][j-1];

2、保持队伍数目不变。把这个人c添加到每种组队方式的任一队伍中,则队伍变成了{ac,b},{a,bc},{abc},添加3种,dp[i][j]=dp[i-1][j]*j;

则能够用dp[i][j]表示 i个人分成j组队的方案数,dp[i][j]=dp[i-1][j-1]+dp[i-1][j]*j;

#include<stdio.h>
#include<math.h>
#include<string.h>
#include<stdlib.h>
#include<algorithm>
#include<vector>
using namespace std;
#define LL __int64
#define N 26
const int inf=0x1f1f1f1f;
LL dp[N][N];
LL f[N];
void inti()
{
int i,j;
memset(dp,0,sizeof(dp));
memset(f,0,sizeof(f));
dp[1][1]=f[1]=1;
for(i=2;i<N;i++)
{
for(j=1;j<=i;j++)
{
dp[i][j]=dp[i-1][j-1]+dp[i-1][j]*j;
f[i]+=dp[i][j];
}
}
}
int main()
{
int c,n,i,j;
inti();
scanf("%d",&c);
while(c--)
{
scanf("%d",&n);
printf("%I64d\n",f[n]);
}
return 0;
}

hdu 1292 &quot;下沙野骆驼&quot;ACM夏令营 (递推)的更多相关文章

  1. HDU 1207 汉诺塔II (找规律,递推)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1207 汉诺塔II Time Limit: 2000/1000 MS (Java/Others)     ...

  2. HDU 5446——Unknown Treasure——————【CRT+lucas+exgcd+快速乘+递推求逆元】

    Each test case starts with three integers n,m,k(1≤m≤n≤1018,1≤k≤10) on a line where k is the number o ...

  3. HDU 2049 不容易系列之(4)——考新郎 (递推,含Cmn公式)

    不容易系列之(4)——考新郎 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)To ...

  4. 致初学者(四):HDU 2044~2050 递推专项习题解

    所谓递推,是指从已知的初始条件出发,依据某种递推关系,逐次推出所要求的各中间结果及最后结果.其中初始条件或是问题本身已经给定,或是通过对问题的分析与化简后确定.关于递推的知识可以参阅本博客中随笔“递推 ...

  5. hdu 1267 下沙的沙子有几粒? (递推)

    下沙的沙子有几粒? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

  6. HDU——1267 下沙的沙子有几粒?

    下沙的沙子有几粒? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

  7. hdu1527下沙小面的(二)

    B - 下沙小面的(2) Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit ...

  8. C - 下沙小面的(2)

    C – 下沙小面的(2)Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64uSubmit StatusDes ...

  9. System.Web.HttpRequestValidationException: 从客户端(dbFlag=&quot;&lt;soap:Envelope xmlns...&quot;)中检测到有潜在危险的 Request.Form 值。

    System.Web.HttpRequestValidationException: 从客户端(dbFlag="<soap:Envelope xmlns...")中检测到有潜 ...

随机推荐

  1. mysql新加入用户与删除用户详细操作命令

    方法1 :使用mysql root(root权限)用户登陆直接赋权也能够创建用户 /usr/bin/mysqladmin -u root password 123456 mysql -uroot -p ...

  2. 从头认识java-17.4 具体解释同步(3)-对象锁

    这一章节我们接着上一章节的问题,给出一个解决方式:对象锁. 1.什么是对象锁? 对象锁是指Java为临界区synchronized(Object)语句指定的对象进行加锁,对象锁是独占排他锁. 2.什么 ...

  3. TabControl里面添加From

    private void dynamicDll() { string dllName = "dll"; Assembly ass = Assembly.Load(dllName); ...

  4. 洛谷 P2755 洗牌问题

    P2755 洗牌问题 题目描述 给你2N张牌,编号为1,2,3..n,n+1,..2n.这也是最初的牌的顺序. 一次洗牌是把序列变为n+1,1,n+2,2,n+3,3,n+4,4..2n,n.可以证 ...

  5. Android实践 -- 对apk进行系统签名

    对apk进行系统签名 签名工具 网盘下载 ,需要Android系统的签名的文件 platform.x509.pem 和 platform.pk8 这个两个文件在Android源码中的 ./build/ ...

  6. MWPhotoBrowser 属性详解 和代理解释

    --------0.MWPhoto简单属性解释---------------- MWPhoto *photo = [MWPhoto photoWithURL:[NSURL URLWithString: ...

  7. 加固linux

    http://linoxide.com/linux-command/password-aging-secure-linux-access/

  8. poj1679 The Unique MST(判定次小生成树)

    The Unique MST Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 23180   Accepted: 8235 D ...

  9. 9.5 Binder系统_驱动情景分析_transaction_stack机制

    参考文章:http://www.cnblogs.com/samchen2009/p/3316001.html test_server服务进程可能有多个线程,而在发送数据的时候handle只表示了那个进 ...

  10. stm32四种输入

    1.          上拉输入(GPIO_Mode_IPU)   上拉输入就是信号进入芯片后加了一个上拉电阻,再经过施密特触发器转换成0.1信号,读取此时的引脚电平为高电平:   2.       ...