当一个数的二进制表示中,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那里抄的递推写法。关于组合数的计算还要再学习一个,最近数学专题。。。

还有就是边界问题。

#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std; unsigned int S,F;
int C[][]; void init()
{
C[][]=;
C[][]=;C[][]=;
for(int i=;i<;i++)
{
C[i][]=;
for(int j=;j<i;j++)
C[i][j]=C[i-][j-]+C[i-][j];
C[i][i]=;
}
} int getbit(unsigned int x)
{
for(int i=;i>=;i--)
{
if(x&(<<i)) return i+;
}
} int get1(unsigned int x)
{
int ans = ;
for(int i=;i>=;i--)
{
if(x&(<<i)) ans++;
}
return ans;
} unsigned int get0To1(unsigned int x)
{
int n = getbit(x);
int ans = ;
n--;
for(int i=;i<=n;i++)
{
if(i == ) continue;
int mx = i/;
for(int j=;j<mx;j++)
{
ans += C[i-][j];
}
}
return ans;
} int get0(unsigned int x)
{
int ans =;
if(x == ) return ;
for(int i=;i<;i++)
{
if((x&(<<i)) == ) ans++;
else return ans;
}
return ans;
} unsigned int get1ToX(unsigned int x)
{
int one = get1(x),n=getbit(x);
int mx = n/,ans=,cur=;
//printf("x=%d one=%d n=%d\n",x,one,n);
if(one <= mx) ans++;
for(int i=n-;i>=;i--)
{
if((x&(<<i)) == )
{
//printf("gg");
continue;
}
else
{
for(int j=;j<=mx-cur;j++)
{
ans += C[i][j];
}
cur++;
}
}
return ans;
} int main()
{
init();
while(~scanf("%d%d",&S,&F))
{
if(S > F) swap(S,F);
//printf("all1 S=%d F=%d\n",get0To1(S),get0To1(F));
//printf("toX S=%d F=%d\n",get1ToX(S),get1ToX(F));
int ans = (get0To1(F)+get1ToX(F)) - (get0To1(S)+get1ToX(S));
if(get1(S) <= getbit(S)/) ans++;
printf("%d\n",ans); }
}

还有就是边界问题了。

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. 图解IIS8上解决网站第一次访问慢的处理(转载)

    本篇经验以IIS8,Windows Server 2012R2做为案例.IIS8 运行在 Windows Server 2012 and Windows 8 版本以上的平台上.IIS中应用程序池和网站 ...

  2. Nowcoder186C 失衡天平 背包

    题目传送门 题意:给你$N$个数,你可以将其划分为若干对集合(这里所说的集合允许数字重复)(即集合是两个集合两个集合出现),每对集合中两个集合所有元素的和的差的绝对值不超过$M$,可以有数字不在集合内 ...

  3. Luogu P1330 封锁阳光大学

    这是一道神坑题! 刚开始看了题还以为是Tarjan(我也不知道Tarjan有什么用). 然后发现这是染色问题的模板题! 找到没有染色的点,然后将它涂成1(一共只有1,2两种颜色) 与它相连的点进行广搜 ...

  4. python中使用pymongo操作mongo

    MongoDB是由C++语言编写的非关系型数据库,是一个基于分布式文件存储的开源数据库系统,其内容存储形式类似JSON对象,它的字段值可以包含其他文档.数组及文档数组,非常灵活.在这一节中,我们就来看 ...

  5. RabbitMQ TroubleShooting

    RabbitMQ是一款优秀的消息队列中间件,提供了稳定.监控完善的产品,但是软件就会有bug.为了前进路径可以畅通,我们必须了解出现的一些故障的快速处理方式,毕竟在生产环境,时间就是生命,尽快的处理是 ...

  6. TRIO-basic指令--MOVEMODIFY

    Syntax: MOVEMODIFY(position) Parameters: position: Absolute position for the current move to complet ...

  7. 系统、决策、控制研究系列(SSDC)

    本类目主要介绍的书籍来自springer的系列书籍中的一本,对于该系列书籍介绍如下: “系统.决策及控制研究”(SSDC)系列涵盖了在广泛认知的系统.决策及控制的各个领域的快速.最新和高质量的最新发展 ...

  8. Js把Json序列化为Java接受的对象。

    服务器端 Java定义 data class role(var name: String = "", var remark: String = "") data ...

  9. nginx通过https方式反向代理多实例tomcat

    案例说明:前面一层nginx+Keepalived部署的LB,后端两台web服务器部署了多实例的tomcat,通过https方式部署nginx反向代理tomcat请求.配置一如下: 1)LB层的ngi ...

  10. CentOS7下单机部署RabbltMQ环境的操作记录

    一.RabbitMQ简单介绍在日常工作环境中,你是否遇到过两个(多个)系统间需要通过定时任务来同步某些数据?你是否在为异构系统的不同进程间相互调用.通讯的问题而苦恼.挣扎?如果是,那么恭喜你,消息服务 ...