标签:-- 二进制 个数 ace open 例子 print span 目的
给定一个正整数N,求最小的、比N大的正整数M,使得M与N的二进制表示中有相同数目的1。
举个例子,假如给定的N为78,其二进制表示为1001110,包含4个1,那么最小的比N大的并且二进制表示中只包含4个1的数是83,其二进制是1010011,因此83就是答案。
输入若干行,每行一个数n(1≤n≤1000000),输入"0"结束。
输出若干行对应的值。
1
2
3
4
78
0
2
4
5
8
83
容易想到,当$n$加上$lowbit(n)$时,$1$的数量一定会减少$cnt$,我们只需要从末位开始找$cnt$个$0$位,将其改为$1$,得到的就是$m$了。
#include <iostream> #include <cstdio> #define lowbit(x) ((x) & -(x)) using namespace std; int n, m; int cnt; int main() { int tmp; while(scanf("%d", &n) && n) { m = n + lowbit(n); tmp = n; while(tmp) ++cnt, tmp -= lowbit(tmp); tmp = m; while(tmp) --cnt, tmp -= lowbit(tmp); tmp = 1; while(cnt) { if((tmp & lowbit(m)) ^ 1) --cnt, m += tmp; tmp <<= 1; } printf("%d\n", m); } return 0; }
标签:-- 二进制 个数 ace open 例子 print span 目的
原文地址:https://www.cnblogs.com/kcn999/p/10803392.html