fafu 1411
想了好久都没想到怎么去判断当分类dp的时候大于或者等于要求的 值时应该怎么半 后来经过停了 qlx的想法 然后就 敲了出来
这题说的是 一个整数 分解成几个素数的和 按这个数的含有的最大素数 进行排列给定的一个数 小于200 求这个数的 第k大的数是什么,然后让你计算出 第k大是组成数是什么.
分类进行dp 比如起始位进行dp 分类进行的dp可以按照从小到大的排列进行 大的数 只能用比他小的数 进行dp 类似于完全背包,这样在查找的时候也分类进行查找记得从大到小查找ok
- #include <iostream>
- #include<cstdio>
- #include<string.h>
- using namespace std;
- bool a[300];
- int p[50],dp[50][300],ber[100];
- void prime()
- {
- int count=0;
- memset(a,0,sizeof(a));
- for(int i=2;i<=201;i++)
- {
- if(a[i]==0){p[count++]=i;}
- for(int j=0,k;j<count&&(k=p[j]*i)<=201;j++)
- {
- a[k]=1;
- if(i%p[j]==0) break;
- }
- }
- //for(int i=0;i<count;i++)
- // printf("%d ",p[i]);
- }
- int work(int n,int k,int H)
- {
- int count=0;
- for(int i=H;i>=0;i--)
- {
- if(dp[i][n]<k)
- k-=dp[i][n];
- else if(dp[i][n]>=k)
- while(dp[i][n]>=k)
- {
- ber[count++]=p[i];
- n-=p[i];
- if(dp[i][n]<k)
- {
- k-=dp[i][n];
- break;
- }
- if(k==0||n==0) break;
- }
- if(k==0||n==0) break;
- }
- return count;
- }
- int main()
- {
- //eopen("data.txt","r",stdin);
- prime();
- int n,k,H,sum;
- int i,j;
- while(scanf("%d%d",&n,&k)==2)
- {
- sum=0;
- memset(dp,0,sizeof(dp));
- if(!n&&!k) break;
- for(i=0;i<46;i++)
- {
- if(p[i]>n) {H=i;break;}
- dp[i][p[i]]=1;
- int st=p[i];
- for( j=i;j>=0;j--)
- {
- for(int g=st+p[j];g<=n;g++)
- if(dp[g-p[j]]!=0)
- {
- dp[i][g]+=dp[i][g-p[j]];
- }
- }
- sum+=dp[i][n];
- }
- printf("%d\n",sum);
- if(k>sum)k=sum;
- int T=work(n,k,H);
- printf("%d=",n);
- for(i=0;i<T-1;i++)
- printf("%d+",ber[i]);
- printf("%d\n",ber[T-1]);
- }
- return 0;
- }
fafu 1411的更多相关文章
- bzoj 1411 [ZJOI2009]硬币游戏
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1411 [题意] N个硬币放在一个有2*N个位置的圆桌上,求T次操作后的情况.对于一个操 ...
- 【UVA 1411】 Ants (KM)
Young naturalist Bill studies ants in school. His ants feed onplant-louses that live on apple trees. ...
- UVA 1411 - Ants(二分图完美匹配)
UVA 1411 - Ants 题目链接 题意:给定一些黑点白点,要求一个黑点连接一个白点,而且全部线段都不相交 思路:二分图完美匹配,权值存负的欧几里得距离,这种话,相交肯定比不相交权值小,所以做一 ...
- BZOJ 1411&&Vijos 1544 : [ZJOI2009]硬币游戏【递推,快速幂】
1411: [ZJOI2009]硬币游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 897 Solved: 394[Submit][Status ...
- FAFU 1395
动态规划:...翻牌FAFU 1395 动态规划
- FAFU 1136 最长递增子序列
http://acm.fafu.edu.cn/problem.php?id=1136 根据dp建边,建边的时候记得判断如果原本数的大小就ok了 好久没在自家OJ上刷了 #include <ios ...
- 穷举(四):POJ上的两道穷举例题POJ 1411和POJ 1753
下面给出两道POJ上的问题,看如何用穷举法解决. [例9]Calling Extraterrestrial Intelligence Again(POJ 1411) Description A mes ...
- uva 1411 Ants (权值和最小的完美匹配---KM算法)
uva 1411 Ants Description Young naturalist Bill studies ants in school. His ants feed on plant-louse ...
- Calling Extraterrestrial Intelligence Again POJ 1411
题目链接:http://poj.org/problem?id=1411 题目大意:找两个素数p,q满足a/b<=p/q<=1 且p*q<=m,求p*q最大的一组素数对. 第一次想的是 ...
随机推荐
- shell 中的$0 $1 $* $@ $# $$ $? $() $(())
$0: 脚本本身文件名称 : 命令行第一个参数,$2为第二个,以此类推 $*: 所有参数列表 $@: 所有参数列表 $#: 参数个数 $$: 脚本运行时的PID $?: 脚本退出码 ∗与@的区别 当命 ...
- Build step 'Execute Windows batch command' marked build as failure
坑爹的Jenkis,在执行windows命令编译.NET项目的时候命令执行成功了,但是却还是报了这样一个错: Build step 'Execute Windows batch command' ma ...
- 【咸鱼教程】Wing动画编辑器创建精美(一般-_-)开场动画
游戏中会用着一些简单的动画,公司一般使用的dragonbones制作,导出二进制格式或者MC来使用.感觉一些简单动画直接使用动画编辑器更加简便些. 引擎版本:5.0.14wing版本:4.1.0 一 ...
- iOS 循环引用 委托 (实例说明)
如何避免循环引用造成的内存泄漏呢: 以delegate模式为例(viewcontroller和view之间就是代理模式,viewcontroller有view的使用权,viewcontroller同时 ...
- yii---左查询使用
看到一些做关联查询的示例,例如使用hasMany(一对多),还是有一个hasOne(一对一)的,没有细看,下面是我看到的一个比较好用的一个: $query = (new \yii\db\Query() ...
- Centos6.5安装mysql 5.7
1.在官网下载安装包:https://dev.mysql.com/downloads/mysql/5.7.html#downloads mysql-5.7.10-linux-glibc2.5-x86_ ...
- 转利用python实现电影推荐
“协同过滤”是推荐系统中的常用技术,按照分析维度的不同可实现“基于用户”和“基于产品”的推荐. 以下是利用python实现电影推荐的具体方法,其中数据集源于<集体编程智慧>一书,后续的编程 ...
- 9.7 Django 书单列表页面
昨天的迭代版本,增加了编辑出版社,编辑列表,增添了返回页面! 具体的看 github : https://github.com/TrueNewBee/pythonDemo 看一下效果图: 整体来说还是 ...
- saltstack------安装篇
一.环境准备 系统:centos7 and centos6.8 IP 系统 172.16.1.10 centos7 172.16.1.11 centos7 172.16.1.21 centos6. ...
- camke中关于变量的一些知识
一.cmake变量引用的方式: 在cmake中,使用${}进行变量的引用.在IF等语句中,是直接使用变量名而不是通过${}取值 二.cmake自定义变量的方式: 主要有隐式定义和显式定义两种,前面举了 ...