想了好久都没想到怎么去判断当分类dp的时候大于或者等于要求的 值时应该怎么半 后来经过停了 qlx的想法 然后就 敲了出来

这题说的是 一个整数 分解成几个素数的和  按这个数的含有的最大素数 进行排列给定的一个数 小于200 求这个数的 第k大的数是什么,然后让你计算出 第k大是组成数是什么.

分类进行dp 比如起始位进行dp  分类进行的dp可以按照从小到大的排列进行 大的数 只能用比他小的数 进行dp 类似于完全背包,这样在查找的时候也分类进行查找记得从大到小查找ok

  1. #include <iostream>
  2. #include<cstdio>
  3. #include<string.h>
  4. using namespace std;
  5. bool a[300];
  6. int p[50],dp[50][300],ber[100];
  7. void prime()
  8. {
  9. int count=0;
  10. memset(a,0,sizeof(a));
  11. for(int i=2;i<=201;i++)
  12. {
  13. if(a[i]==0){p[count++]=i;}
  14. for(int j=0,k;j<count&&(k=p[j]*i)<=201;j++)
  15. {
  16. a[k]=1;
  17. if(i%p[j]==0) break;
  18. }
  19. }
  20. //for(int  i=0;i<count;i++)
  21. // printf("%d ",p[i]);
  22. }
  23. int work(int n,int k,int H)
  24. {
  25. int count=0;
  26. for(int i=H;i>=0;i--)
  27. {
  28. if(dp[i][n]<k)
  29. k-=dp[i][n];
  30. else if(dp[i][n]>=k)
  31. while(dp[i][n]>=k)
  32. {
  33. ber[count++]=p[i];
  34. n-=p[i];
  35. if(dp[i][n]<k)
  36. {
  37. k-=dp[i][n];
  38. break;
  39. }
  40. if(k==0||n==0) break;
  41. }
  42. if(k==0||n==0) break;
  43. }
  44. return count;
  45. }
  46. int main()
  47. {
  48. //eopen("data.txt","r",stdin);
  49. prime();
  50. int n,k,H,sum;
  51. int i,j;
  52. while(scanf("%d%d",&n,&k)==2)
  53. {
  54. sum=0;
  55. memset(dp,0,sizeof(dp));
  56. if(!n&&!k) break;
  57. for(i=0;i<46;i++)
  58. {
  59. if(p[i]>n) {H=i;break;}
  60. dp[i][p[i]]=1;
  61. int st=p[i];
  62. for( j=i;j>=0;j--)
  63. {
  64. for(int g=st+p[j];g<=n;g++)
  65. if(dp[g-p[j]]!=0)
  66. {
  67. dp[i][g]+=dp[i][g-p[j]];
  68. }
  69. }
  70. sum+=dp[i][n];
  71. }
  72. printf("%d\n",sum);
  73. if(k>sum)k=sum;
  74. int T=work(n,k,H);
  75. printf("%d=",n);
  76. for(i=0;i<T-1;i++)
  77. printf("%d+",ber[i]);
  78. printf("%d\n",ber[T-1]);
  79. }
  80. return 0;
  81. }

fafu 1411的更多相关文章

  1. bzoj 1411 [ZJOI2009]硬币游戏

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1411 [题意] N个硬币放在一个有2*N个位置的圆桌上,求T次操作后的情况.对于一个操 ...

  2. 【UVA 1411】 Ants (KM)

    Young naturalist Bill studies ants in school. His ants feed onplant-louses that live on apple trees. ...

  3. UVA 1411 - Ants(二分图完美匹配)

    UVA 1411 - Ants 题目链接 题意:给定一些黑点白点,要求一个黑点连接一个白点,而且全部线段都不相交 思路:二分图完美匹配,权值存负的欧几里得距离,这种话,相交肯定比不相交权值小,所以做一 ...

  4. BZOJ 1411&&Vijos 1544 : [ZJOI2009]硬币游戏【递推,快速幂】

    1411: [ZJOI2009]硬币游戏 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 897  Solved: 394[Submit][Status ...

  5. FAFU 1395

    动态规划:...翻牌FAFU 1395 动态规划

  6. FAFU 1136 最长递增子序列

    http://acm.fafu.edu.cn/problem.php?id=1136 根据dp建边,建边的时候记得判断如果原本数的大小就ok了 好久没在自家OJ上刷了 #include <ios ...

  7. 穷举(四):POJ上的两道穷举例题POJ 1411和POJ 1753

    下面给出两道POJ上的问题,看如何用穷举法解决. [例9]Calling Extraterrestrial Intelligence Again(POJ 1411) Description A mes ...

  8. uva 1411 Ants (权值和最小的完美匹配---KM算法)

    uva 1411 Ants Description Young naturalist Bill studies ants in school. His ants feed on plant-louse ...

  9. Calling Extraterrestrial Intelligence Again POJ 1411

    题目链接:http://poj.org/problem?id=1411 题目大意:找两个素数p,q满足a/b<=p/q<=1 且p*q<=m,求p*q最大的一组素数对. 第一次想的是 ...

随机推荐

  1. PostgreSQL9.3安装tds_fdw扩展

    PostgreSQL从9.x开始支持所谓的外表的功能,就是在PostgreSQL中通过安装一些扩展再进行一些配置可以在本地建立一个外表映射到其他不同类型的数据库(可以大致理解为跨越PostgreSQL ...

  2. Dockerfile的一些demo

    tomcat7.0_jdk1.6 #继承用户创建的sshd镜像FROM yatho:sshd_ubuntu #创建者的基本信息 MAINTAINER yatho (yat_ho@163.com) #设 ...

  3. 【JSP】JSP中的Java脚本

    前言 现代Web开发中,在JSP中嵌入Java脚本不是推荐的做法,因为这样 不利于代码的维护.有很多好的,替代的方法避免在JSP中写Java脚本.本文仅做为JSP体系技术的一个了解.     类成员定 ...

  4. IIS7配置伪静态把后缀名映射为html方案

    1.在IIS新建站点.[创建的时候不用去选择版本和模式,默认即可] 2.选中站点,切换到功能试图,找到“处理程序映射",双击之后,在打开窗口右侧的操作栏目下做如下设置: 1)右边" ...

  5. Centos 7网络文件系统nfs服务的安装与配置

    实验环境>>>>>>>>> nfs服务端:(nfs-server)192.168.100.2 nfs客户端:(nfs-client)192.168 ...

  6. Thinkphp框架下对某个字段查询数据的时候进行唯一过滤,返回唯一不同的值

    方法一. DISTINCT 方法用于返回唯一不同的值 . *distinct方法的参数是一个布尔值. 用法: $data = $Model->Distinct(true)->field(' ...

  7. 美团店铺评价语言处理以及文本分类(logistic regression)

    美团店铺评价语言处理以及分类(LogisticRegression) 第一篇 数据清洗与分析部分 第二篇 可视化部分, 第三篇 朴素贝叶斯文本分类 本文是该系列的第四篇 主要讨论逻辑回归分类算法的参数 ...

  8. Jenkins构建报错(Jenkins is reserved for jobs with matching label expression)解决办法

    Jenkins构建报错Jenkins is reserved for jobs with matching label expression 原因节点配置导致 修改配置

  9. hdu 1525 Euclid's Game【 博弈论】

    Two players, Stan and Ollie, play, starting with two natural numbers. Stan, the first player, subtra ...

  10. PAT-GPLT L1-033 - 出生年 - [简单模拟]

    题目链接:https://www.patest.cn/contests/gplt/L1-033 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standar ...