A67276.汉明距离Ⅰ

入门

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

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

具体而言,汉明距离是一种常见的度量两个非负整数之间相似程度的方法。两个非负整数 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

    5
    10 3
    11 3
    20 1
    20 2
    20 3
    

    输出#1

    52
    62
    42
    114
    177
    
  • 输入#2

    3
    3 1
    3 2
    4 2
    

    输出#2

    4
    6
    9
    

说明/提示

数据范围

  • 1t5001 \le t \le 500
  • 1n500,12k1n1\le n\le 500, 1 \le 2^{k-1} \le n
首页