第一题:最大映射
第二题:木棒拼图
第三题:魔法权值
出 n 个字符串,对于每个 n 个排列 p,按排列给出的顺序(p[0] , p[1] … p[n-1])依次连接这 n 个字符串都能得到一个长度为这些字符串长度之和的字符串。所以按照这个方法一共可以生成 n! 个字符串。
一个字符串的权值等于把这个字符串循环左移 i 次后得到的字符串仍和原字符串全等的数量,i 的取值为 [1 , 字符串长度]。求这些字符串最后生成的 n! 个字符串中权值为 K 的有多少个。
注:定义把一个串循环左移 1 次等价于把这个串的第一个字符移动到最后一个字符的后面。
这个题有两个难点:(1)如何生成这些字符串的全排列组合,从而逐一遍历并且求解组合后字符串的权值。 (2)如何求解它的权值。对于第一个问题,用STL中的next_permutation(p,p+len)实现;对于第二个问题,用next数组求解,左移k位后仍与原字符串相同,这意味着k必须是原字符串的一个循环周期,关于字符串的循环,可以参考我之前的一篇博文。而字符串的最小循环周期就等于Tmin=len-next[len],它的其他周期必然是Tmin的整数倍:Tmin, 2Tmin, 3Tmin...直到超过len,也就是说,一个字符串周期的个数等于len/Tmin. 问题迎刃而解啦~ 我们用O(n)的时间(计算next数组)就能求出字符串的权值,这比双重循环不知道高到哪里去了。
代码:
第四题:或与加