A67278.汉明距离Ⅱ

普及/提高-

通过率:0%

时间限制:1.00s

内存限制:512MB

题目描述

本题与汉明距离Ⅰ题面完全一样,只有数据范围不同。

具体而言,汉明距离是一种常见的度量两个非负整数之间相似程度的方法。两个非负整数 xxyy 的汉明距离定义为 xxyy 的二进制表示中,不同的位数。汉明距离可形式化定义如下:

dH(x,y)=i=0I((x&2i)(y&2i))d_H(x,y)=\sum_{i=0}^{\infty} I\left( \left(x\&2^i\right)\neq\left(y\&2^i\right) \right)

其中 x&yx\&y 表示 xxyy 的按位与运算,II 表示指示函数,即当括号内的条件成立时,II 的值为 11,否则为 00

现在,你需要判断区间 [0,n][0, n] 内有多少个不同的数对 (x,y)(x, y) (0x<yn0\le x<y\le n),满足 xxyy 的汉明距离小于等于 kk,即 dH(x,y)kd_H(x,y)\le k。答案可能很大,你只需要输出答案对 998244353998244353 取模的结果。

输入格式

每个测试输入包含多个测试用例。输入的第一行包含一个正整数 tt,表示测试用例的组数。测试用例的描述如下:

每个测试用例的唯一一行包含两个正整数 nnkk,其含义见题目描述

输出格式

对于每个测试用例,输出的唯一一行包含一个整数,表示答案对 998244353998244353 取模的结果。

输入输出样例

  • 输入#1

    3
    10000 6
    10000 10
    959111 2
    

    输出#1

    22271707
    48943581
    97478112
    

说明/提示

数据范围

  • 1t1061 \le t \le 10^6
  • 1n106,12k1n1\le n\le 10^6, 1 \le 2^{k-1} \le n
首页