母函数 2189 (2011-3-13 14:11)
来源:互联网 发布:文字识别软件破解版 编辑:程序博客网 时间:2024/05/21 00:55
http://acm.hdu.edu.cn/showproblem.php?pid=2189
灾区来了n位志愿者,抗震救灾指挥部需要将他们分为若干个小组,小组的数量不限,但是要求每个小组的人数必须为素数,请问我们有几种分组的方法呢?
input
输入数据首先包含一个正整数C,表示有C组测试用例,然后是C行数据,每行包含一个正整数n(2<=n<=150),表示志愿者的总人数。
output
sample input
3
3
4
5
sample output
1
1
2
思路一:搜索,写完程序后发现,算到150需要1200ms左右的时间,题目要求1000ms以内,试着提交了一下,果然Time out
思路二:贪心,把每次的结果保存下来,后面的利用前面的来做,发现数据怎么都对不上
思路三:母函数,发现此题很符合母函数的思路,每个素数都可以取无限个,于是摸索了一便母函数的思路,AC!
//代码
#include <stdio.h>
#define lmax 155
int c1[lmax+1],c2[lmax+1];
int s[lmax+1];
int main()
{
int t,n,i,j,k;
for(i=0;i<lmax+1;i++)
s[i]=1;
s[0]=s[1]=0;
for(i=2;i<lmax+1;i++)//初始化素数
for(j=2;j<(lmax+1)/i;j++)
s[i*j]=0;
scanf("%d",&t);
while (t--)
{
scanf("%d",&n);
for (i=0;i<=n;i++)
{c1[i]=0; c2[i]=0;}
for (i=0;i<=n;i++) if( i%2==0 )c1[i]=1;
for (i=3;i<=n;i++)
{
if(s[i]){
for (j=0;j<=n;j++){
for (k=0;k+j<=n;k+=i)
{
c2[j+k]+=c1[j];
}
}
for (j=0;j<=n;j++)
{ c1[j]=c2[j]; c2[j]=0; }
}
}
printf("%d\n",c1[n]);
}
return 0;
}
- 母函数 2189 (2011-3-13 14:11)
- HDU 2189 母函数
- 2011-9-13 函数总结
- 14--3成绩处理函数
- 3-14(Reverse函数)
- 深入理解指针函数 (2011-03-22 11:41:48)转载 标签: 指针函数 函数指针
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- 母函数
- C++重点知识回顾
- Android Activity生命周期
- 黑马程序员_Java学习日记6_多线程
- [JAVA] string 和 byte之间的转换
- ACM HDU 1083(二分匹配) (2011-3-9 20:35)
- 母函数 2189 (2011-3-13 14:11)
- Maven实战(七)——常用Maven插件介绍(上)
- 最长影子问题(第六届第二题) (2011-3-15 21:41)
- 三轴正交型传感器的正交性修正算法
- Dream City (第六届ACM) (2011-3-16 10:21)
- 关于SQL Server将一列的多行内容拼接成一行的问题讨论
- 常用Maven插件介绍(下)
- 最短路(纯搜索) (2011-3-19 09:48)
- tar 解压缩命令