#P5772. [JSOI2016] 位运算
[JSOI2016] 位运算
题目描述
JYY 最近在研究位运算。他发现位运算中最有趣的就是异或 (xor) 运算。对于两个数的异或运算,JYY 发现了一个结论:两个数的异或值为 当且仅当他们相等。于是 JYY 又开始思考,对于 个数的异或值会有什么性质呢?
JYY 想知道,如果在 到 的范围内,选出 个不同的整数,并使得这 个整数的异或值为 ,那么一共有多少种选择的方法呢?(选择的不同次序并不作重复统计,请参见样例)
JYY 是一个计算机科学家,所以他脑海里的 非常非常大。为了能够方便的表达,如果我们将 写成一个 串,那么 是由一个较短的 串 重复 次得到的。比如,若 ,,那么 的二进制表示则为 。由于计算的结果会非常大,JYY 只需要你告诉他选择的总数对 取模的结果即可。
输入格式
第一行包含两个正整数 和 ;
接下来一行包含一个由 和 组成的字符串 ;
我们保证 的第一个字符一定为 。
输出格式
一行一个整数,表示选择的方案数对 取模的值。
3 1
100
1
提示
样例说明
唯一的一种选择方法是选择 。
数据范围
对于 的数据,,,。