【今日头条2017后端工程师实习生笔试题解】

第一题:最大映射

 

第二题:木棒拼图

 

第三题:魔法权值

出 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数组)就能求出字符串的权值,这比双重循环不知道高到哪里去了。

代码:

 

第四题:或与加

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值