hdu5491 The Next
2024-09-04 22:36:30
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 740 Accepted Submission(s): 294
Problem Description
Let L denote
the number of 1s in integer D’s
binary representation. Given two integers S1 and S2,
we call D a
WYH number if S1≤L≤S2.
With a given D,
we would like to find the next WYH number Y,
which is JUST larger than D.
In other words, Y is
the smallest WYH number among the numbers larger than D.
Please write a program to solve this problem.
the number of 1s in integer D’s
binary representation. Given two integers S1 and S2,
we call D a
WYH number if S1≤L≤S2.
With a given D,
we would like to find the next WYH number Y,
which is JUST larger than D.
In other words, Y is
the smallest WYH number among the numbers larger than D.
Please write a program to solve this problem.
Input
The first line of input contains a number T indicating
the number of test cases (T≤300000).
Each test case consists of three integers D, S1,
and S2,
as described above. It is guaranteed that 0≤D<231 and D is
a WYH number.
the number of test cases (T≤300000).
Each test case consists of three integers D, S1,
and S2,
as described above. It is guaranteed that 0≤D<231 and D is
a WYH number.
Output
For each test case, output a single line consisting of “Case #X: Y”. X is
the test case number starting from 1. Y is
the next WYH number.
the test case number starting from 1. Y is
the next WYH number.
Sample Input
3
11 2 4
22 3 3
15 2 5
11 2 4
22 3 3
15 2 5
Sample Output
Case #1: 12
Case #2: 25
Case #3: 17
Case #2: 25
Case #3: 17
Source
2015 ACM/ICPC Asia Regional Hefei Online
这题自己没有想到,比赛时是队友做的,后来知道了做法。先把D加1变成m,然后判断m是否满足条件,如果满足就直接输出m,如果不满足,那么有两种情况,第一种是二进制后的1的个数小于s1,那么我们只要从右往左找第一个0,使得其变为1(即加上2^i),如果二进制后的1的个数大于s1,那么我们只要从右往左找第一个1,然后加上(2^i),使其变为0,然后继续下去。
这种方法可行的原因是每次都是使改变最少,所以得到的值一定是成立中最小的。
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
using namespace std;
#define ll long long
#define inf 0x7fffffff
int main()
{
ll n,m,i,j,T,t1,t2,wei,num1=0,num;
int a[40];
scanf("%lld",&T);
while(T--)
{
scanf("%lld%lld%lld",&n,&t1,&t2);
n++;
while(1){
m=n;
wei=0;num=0;
while(m){
a[++wei]=m%2;
if(m%2==1)num++;
m/=2;
}
if(num<t1){
for(i=1;i<=wei;i++){
if(a[i]==0){
j=i;break;
}
}
n+=(1<<(j-1));
}
else if(num>t2){
for(i=1;i<=wei;i++){
if(a[i]==1){
j=i;break;
}
}
n+=(1<<(j-1) );
}
else break;
}
num1++;
printf("Case #%lld: %lld\n",num1,n);
}
return 0;
}
最新文章
- ajax实例详解
- 【转】清理Kylin的中间存储数据(HDFS &; HBase Tables)
- MyEclipse安装JS代码提示(Spket插件)
- C语言调试的几种方法
- 【Unity3D】Unity3D之 注册表动态存取游戏存档——PlayerPrefs类
- ssh 认证指定端口
- CAAnimation动画--(旋转/缩放/移动/闪烁)
- jdbc驱动的类加载过程
- 关于熊猫认证软件IOS安装步骤教程(适用于其他软件)
- Java面向对象——类,对象和方法
- 【转】解决在Android设备播放音频与其他应用重音的问题,并监听耳机的控制按钮
- 如何解决普通用户使用sudo找不到命令
- win7语音识别开发(sapi)
- Git HTTPS 方式自动保存用户名密码
- [翻译] SoundManager 音频管理器
- 部署项目到远程tomcat的413 Request Entity Too Large报错处理
- input placeholder 在chrome 浏览器自动填充时,背景色覆盖原有背景图片问题。
- fs.watch 爬坑
- 5 Django-1的路由层(URLconf)
- Oracle 12c 多租户在 CDB 中 Plug A PDB,Unplugging A PDB
热门文章
- 【转】Js中的window.parent ,window.top,window.self 详解
- 24V转5V芯片,高输入电压LDO线性稳压器
- 解决JS获取中文参数出现的乱码问题
- three.js cannon.js物理引擎地形生成器和使用指针锁定控件
- SpringCloud Alibaba Nacos注册中心源码浅析
- Kubernetes 存储简介
- VGA调试心得
- USB2514集线器调试总结
- Any race is a bug. When there is a race, the compiler is free to do whatever it wants.
- 在Ubuntu安装Docker