CF1988C Increasing Sequence with Fixed OR
题目描述
给定一个正整数 $n$。请找出满足以下条件的最长正整数序列 $a=[a_1,a_2,\ldots,a_k]$,并输出该序列:
- 对于所有 $1\le i\le k$,都有 $a_i\le n$。
- 序列 $a$ 严格递增。即对于所有 $2\le i\le k$,都有 $a_i>a_{i-1}$。
- 对于所有 $2\le i\le k$,都有 $a_i\,|\,a_{i-1}=n$,其中 $|$ 表示[按位或运算](https://en.wikipedia.org/wiki/Bitwise_operation#OR)。
输入格式
每个测试点包含多组测试数据。第一行包含一个整数 $t$($1 \le t \le 1000$),表示测试数据的组数。
每组测试数据仅包含一行,一个整数 $n$($1\le n\le 10^{18}$)。
保证所有测试数据中最长合法序列的长度之和不超过 $5\cdot 10^5$。
输出格式
对于每组测试数据,输出两行。第一行输出你构造的序列的长度 $k$。第二行输出 $k$ 个正整数,表示该序列。若存在多个最长序列,你可以输出其中任意一个。
说明/提示
由 ChatGPT 4.1 翻译