CFCF2146D2.Max Sum OR (Hard Version)
普及+/提高
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的 Hard 版本。不同之处在于本版本中,0≤l≤r<230。只有在你解决了所有版本的本题后,才可以进行 Hack。
给定两个整数 l 和 r(l≤r)。
设 n=r−l+1。我们将创建两个长度为 n 的数组 a 和 b。一开始,a 和 b 均为 [l,l+1,…,r]。你的任务是任意重新排列数组 a,使下面的值最大化:
i=1∑n(ai∣bi)
其中,∣ 表示按位或运算。
你还需要给出一种重新排列数组 a 的方案。
输入格式
每组测试包含多组数据。第一行包含整数 t(1≤t≤104),表示测试组数。
接下来每组测试一行,包含两个整数 l 和 r(0≤l≤r<230),即数组 a 的最小和最大元素。
设 n=r−l+1。保证所有测试用例中,所有 n 之和不超过 2⋅105。
输出格式
对于每组测试数据,输出两行。
第一行输出一个整数,表示最大的 i=1∑n(ai∣bi)。
第二行输出 n 个两两不同的整数 a1,a2,…,an,表示重新排列后的数组 a。
如果有多种方案,可以任选其一输出。
输入输出样例
输入#1
7 0 3 0 9 0 15 6 10 1 4 3 6 1000000007 1000000009
输出#1
12 3 2 1 0 90 7 8 5 4 3 2 9 0 1 6 240 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 70 10 8 7 6 9 20 2 1 4 3 28 4 3 6 5 3000000039 1000000008 1000000007 1000000009
说明/提示
在第一个测试用例中,重排后的数组 a 为 [3,2,1,0]。表达式值为 (3∣0)+(2∣1)+(1∣2)+(0∣3)=3+3+3+3=12。可以证明这是表达式最大可能值。
在第二个测试用例中,重排后的数组 a 为 [7,8,5,4,3,2,9,0,1,6]。表达式值为 90。可以证明这是最大可能值。
在第三个测试用例中,可以证明 240 是表达式最大可能值。
在第四个测试用例中,重排后的数组 a 为 [10,8,7,6,9]。表达式值为 (10∣6)+(8∣7)+(7∣8)+(6∣9)+(9∣10)=14+15+15+15+11=70。可以证明这是最大可能值。