CF1761D Carry Bit

题目描述

设 $f(x,y)$ 表示 $x+y$ 在二进制下的进位次数(即 $f(x,y)=g(x)+g(y)-g(x+y)$,其中 $g(x)$ 表示 $x$ 的二进制表示中 $1$ 的个数)。 给定两个整数 $n$ 和 $k$,求有多少有序对 $(a,b)$ 满足 $0 \leq a,b < 2^n$,且 $f(a,b)=k$。注意,对于 $a\ne b$,$(a,b)$ 和 $(b,a)$ 被视为两个不同的有序对。 由于答案可能很大,请输出答案对 $10^9+7$ 取模后的结果。

输入格式

每组测试数据仅一行,包含两个整数 $n$ 和 $k$($0\leq k

输出格式

输出一个整数,表示答案对 $10^9+7$ 取模后的结果。

说明/提示

以下是一些关于进位的示例: $$ \begin{aligned} &\begin{array}{r} 1_{\ \ }1_{\ \ }1\\ +\ _{1}1_{\ \ }0_{\ \ }0\\ \hline \ 1_{\ \ }0_{\ \ }1_{\ \ }1 \end{array} &\begin{array}{r} \ 1_{\ \ }0_{\ \ }1\\ +\ _{\ \ }0_{\ \ }0_{1}1\\ \hline \ 0_{\ \ }1_{\ \ }1_{\ \ }0 \end{array} & &\begin{array}{r} \ 1_{\ \ }0_{\ \ }1\\ +\ _{1}0_{1}1_{1}1\\ \hline \ 1_{\ \ }0_{\ \ }0_{\ \ }0 \end{array} \end{aligned} $$ 所以 $f(7,4)=1$,$f(5,1)=1$,$f(5,3)=3$。 在第一个测试用例中,所有满足条件的有序对为 $(1,1),(1,5),(2,2),(2,3),(3,2),(4,4),(4,5),(4,6),(4,7),(5,1),(5,4),(5,6),(6,4),(6,5),(7,4)$。 由 ChatGPT 4.1 翻译