当一个数的二进制表示中,0的个数大于或等于1的个数时,叫做RoundNumber。求从S到F两个数(包含)之间的RoundNumber个数。

这类题一般都是先求出0到N的个数,然后两个相减。

由于题目是考虑二进制中01的个数,当位数固定时,很方便计算。于是从位数方面解决问题。

设N表示成二进制的位数为len。把0到N分为两部分。

  -位数为[0,len-1]时,可以通过简单的排列组合计算出结果。

  -位数为len时,逐位进行分析。假设N是24,表示成二进制是1 1000,1的个数是2,len/2 =2。

   最高位一定是1,否则就不是len位了。

   第二位是1,如果第二位是0,则后面的三位可以有一个1,也可以没有1,RoundNumber就是C31 +C30 个。

   后面的位都是0,这时不能将其替换成1,从0变成1将会比N更大。

于是分两步就求助了0-N的个数。

中间有两个小问题。一个是组合数的计算,我是从kuangbin那里抄的递推写法。关于组合数的计算还要再学习一个,最近数学专题。。。

还有就是边界问题。

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4.  
  5. using namespace std;
  6.  
  7. unsigned int S,F;
  8. int C[][];
  9.  
  10. void init()
  11. {
  12. C[][]=;
  13. C[][]=;C[][]=;
  14. for(int i=;i<;i++)
  15. {
  16. C[i][]=;
  17. for(int j=;j<i;j++)
  18. C[i][j]=C[i-][j-]+C[i-][j];
  19. C[i][i]=;
  20. }
  21. }
  22.  
  23. int getbit(unsigned int x)
  24. {
  25. for(int i=;i>=;i--)
  26. {
  27. if(x&(<<i)) return i+;
  28. }
  29. }
  30.  
  31. int get1(unsigned int x)
  32. {
  33. int ans = ;
  34. for(int i=;i>=;i--)
  35. {
  36. if(x&(<<i)) ans++;
  37. }
  38. return ans;
  39. }
  40.  
  41. unsigned int get0To1(unsigned int x)
  42. {
  43. int n = getbit(x);
  44. int ans = ;
  45. n--;
  46. for(int i=;i<=n;i++)
  47. {
  48. if(i == ) continue;
  49. int mx = i/;
  50. for(int j=;j<mx;j++)
  51. {
  52. ans += C[i-][j];
  53. }
  54. }
  55. return ans;
  56. }
  57.  
  58. int get0(unsigned int x)
  59. {
  60. int ans =;
  61. if(x == ) return ;
  62. for(int i=;i<;i++)
  63. {
  64. if((x&(<<i)) == ) ans++;
  65. else return ans;
  66. }
  67. return ans;
  68. }
  69.  
  70. unsigned int get1ToX(unsigned int x)
  71. {
  72. int one = get1(x),n=getbit(x);
  73. int mx = n/,ans=,cur=;
  74. //printf("x=%d one=%d n=%d\n",x,one,n);
  75. if(one <= mx) ans++;
  76. for(int i=n-;i>=;i--)
  77. {
  78. if((x&(<<i)) == )
  79. {
  80. //printf("gg");
  81. continue;
  82. }
  83. else
  84. {
  85. for(int j=;j<=mx-cur;j++)
  86. {
  87. ans += C[i][j];
  88. }
  89. cur++;
  90. }
  91. }
  92. return ans;
  93. }
  94.  
  95. int main()
  96. {
  97. init();
  98. while(~scanf("%d%d",&S,&F))
  99. {
  100. if(S > F) swap(S,F);
  101. //printf("all1 S=%d F=%d\n",get0To1(S),get0To1(F));
  102. //printf("toX S=%d F=%d\n",get1ToX(S),get1ToX(F));
  103. int ans = (get0To1(F)+get1ToX(F)) - (get0To1(S)+get1ToX(S));
  104. if(get1(S) <= getbit(S)/) ans++;
  105. printf("%d\n",ans);
  106.  
  107. }
  108. }

还有就是边界问题了。

POJ3252-RoundNumbers-排列组合的更多相关文章

  1. 学习sql中的排列组合,在园子里搜着看于是。。。

    学习sql中的排列组合,在园子里搜着看,看到篇文章,于是自己(新手)用了最最原始的sql去写出来: --需求----B, C, F, M and S住在一座房子的不同楼层.--B 不住顶层.C 不住底 ...

  2. .NET平台开源项目速览(11)KwCombinatorics排列组合使用案例(1)

    今年上半年,我在KwCombinatorics系列文章中,重点介绍了KwCombinatorics组件的使用情况,其实这个组件我5年前就开始用了,非常方便,麻雀虽小五脏俱全.所以一直非常喜欢,才写了几 ...

  3. 【原创】开源.NET排列组合组件KwCombinatorics使用(三)——笛卡尔积组合

           本博客所有文章分类的总目录:本博客博文总目录-实时更新 本博客其他.NET开源项目文章目录:[目录]本博客其他.NET开源项目文章目录 KwCombinatorics组件文章目录: 1. ...

  4. 【原创】开源.NET排列组合组件KwCombinatorics使用(二)——排列生成

           本博客所有文章分类的总目录:本博客博文总目录-实时更新 本博客其他.NET开源项目文章目录:[目录]本博客其他.NET开源项目文章目录 KwCombinatorics组件文章目录: 1. ...

  5. 【原创】开源.NET排列组合组件KwCombinatorics使用(一)—组合生成

           本博客所有文章分类的总目录:本博客博文总目录-实时更新 本博客其他.NET开源项目文章目录:[目录]本博客其他.NET开源项目文章目录 KwCombinatorics组件文章目录: 1. ...

  6. hdu1521 排列组合(指数型母函数)

    题意: 有n种物品,并且知道每种物品的数量ki.要求从中选出m件物品的排数.         (全题文末) 知识点: 普通母函数 指数型母函数:(用来求解多重集的排列问题) n个元素,其中a1,a2, ...

  7. [leetcode] 题型整理之排列组合

    一般用dfs来做 最简单的一种: 17. Letter Combinations of a Phone Number Given a digit string, return all possible ...

  8. 排列组合算法(PHP)

    用php实现的排列组合算法.使用递归算法,效率低,胜在简单易懂.可对付元素不多的情况. //从$input数组中取$m个数的组合算法 function comb($input, $m) { if($m ...

  9. iOS多线程中,队列和执行的排列组合结果分析

    本文是对以往学习的多线程中知识点的一个整理. 多线程中的队列有:串行队列,并发队列,全局队列,主队列. 执行的方法有:同步执行和异步执行.那么两两一组合会有哪些注意事项呢? 如果不是在董铂然博客园看到 ...

  10. leetcode-Combinations 复习复习排列组合

    Combinations 题意: 根据给定的n和k,生成从1到n范围内长度为k的排列组合 示例: n=4 k=2 [[1, 2], [1, 3], [1, 4], [2, 1], [2, 3], [2 ...

随机推荐

  1. 学习Android(入门基础和实用教程)

    为了方便大家学习,准备录制Android基础篇的视频教程, https://item.taobao.com/item.htm?spm=0.7095261.0.0.17a61debAKIDPI& ...

  2. Struts学习总结-02 上传文件

    Struts 2框架提供了内置支持处理文件上传使用基于HTML表单的文件上传.上传一个文件时,它通常会被存储在一个临时目录中,他们应该由Action类进行处理或移动到一个永久的目录,以确保数据不丢失. ...

  3. [Oracle]OWI学习笔记--001

    [Oracle]OWI学习笔记--001 在 OWI 的概念里面,最为重要的是 等待事件 和 等待时间. 等待事件发生时,需要通过 P1,P2,P3 查看具体的资源. 可以通过 v$session_w ...

  4. 我的物联网项目专题移到网站:http://51jdk.com

    我的物联网项目专题移到网站:http://51jdk.com

  5. item 3: 理解decltype

    本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 decltype是一个奇怪的东西.给出一个名字或者一个表达式,de ...

  6. 安装zkpython出错

    pip3 install zkpython==0.4.2 提示:zookeeper.c:20:23: 致命错误:zookeeper.h:没有那个文件或目录 解决: 1.是否安装python-devel ...

  7. python基础学习笔记(七)

    本章介绍如何将语句组织成函数,这样,可以告诉计算机如何做事. 下面编写一小段代码计算婓波那契数列(前两个数的和是第三个数) fibs = [0,1] # 定义一个列表,初始内容是0,1 for i i ...

  8. linux-IO重定向-文本流重定向

    输出重定向的追加和覆盖 标准输出就这两种: 覆盖和追加 >> 是重定向操作符 1 是 命令的文件描述符 重定向操作符合文件描述符之间不能存在空白符 否则1会被当做是文件被读取 将正确和错误 ...

  9. 1017 B. The Bits

    链接 [http://codeforces.com/contest/1017/problem/B] 题意 给你两个长度为n,包含0和1的字符串a和b,有一种操作swap a中的任意两个字符使得a&am ...

  10. linux及安全第四周总结

    学习内容:使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用 一.用户态.内核态 权限分级——为了系统本身更稳定,使系统不宜崩溃.(并不是所有程序员缩写的代码都很健壮!!) x86 CP ...