A92169.abc269C - Submask
普及/提高-
官方
通过率:0%
时间限制:1.00s
内存限制:128MB
题目描述
问题陈述
给你一个非负整数 N 。按升序打印所有满足以下条件的非负整数 x 。
- 在 x 的二进制表示中包含 1 的数字位置集合是在 N 的二进制表示中包含 1 的数字位置集合的子集。
- 也就是说,对于每个非负整数 k 都成立:如果 x 的 2k 位上的数字是 1 ,那么 N 的 2k 位上的数字就是 1 。
数据范围
- N 是整数。
- 0≤N<260
- 在 N 的二进制表示中,最多有 15 个数位包含 1 。
输入格式
输入内容由标准输入法提供,格式如下
N
输出格式
将答案按升序打印为十进制整数,每行一个。
输入输出样例
输入#1
11
输出#1
0 1 2 3 8 9 10 11
输入#2
0
输出#2
0
输入#3
576461302059761664
输出#3
0 524288 549755813888 549756338176 576460752303423488 576460752303947776 576461302059237376 576461302059761664
说明/提示
样例一解释:
N=11(10) 的二进制表示为 1011(2) 。
满足条件的非负整数 x 是:
- 0000(2)=0(10)
- 0001(2)=1(10)
- 0010(2)=2(10)
- 0011(2)=3(10)
- 1000(2)=8(10)
- 1001(2)=9(10)
- 1010(2)=10(10)
- 1011(2)=11(10)
输入可能不适合32 位有符号整数。