E. Xor-sequences
time limit per test
3 seconds
memory limit per test
256 megabytes
input
standard input
有n个整数a1,a2,...,an.
整数序列x1,x2,...,xk,如果对于每1≤i≤k-1,数字xi xi+1的二进制表示中的1个数是3的倍数,并且对于所有1≤i≤k,xi 属于{a1,a2,...,an},这称为“xor序列”。符号用于二进制异或运算。
请问有多少种合法的构造序列
Input
第一行两个数字n和k,表示数集大小和所需构造序列的长度, 接下来一行有n个数字,代表数集中的元素。
Output
输出一行,表示答案,由于答案可能会很大,请对10^9+7取模后输出。
You are given
n integers
a1,a2,...,an.
A sequence of integers
x1,x2,...,xk is called a "
xor-sequence" if for every
1≤i≤k-1 the number of ones in the binary representation of the number
xi xi+1's is a multiple of
3 and
for all
1≤i≤k. The symbol
is used for the binary exclusive or operation.
How many "
xor-sequences" of length
k exist? Output the answer modulo
109+7.
Note if a=[1,1] and k=1 then the answer is 2, because you should consider the ones from a as different.
Output
Print the only integer
c − the number of "
xor-sequences" of length
k modulo
109+7.