2014百度武汉站研发题

1、给定任意一个整整数、求比这个数大且最小的不重复数、就是想领两位不同,例如1231

算法思路

1.  将给定的long数加1。

2.  从这个数开始检测是否为重复数,如果不是,ok,这个数就是最终结果。如果是,那么从数的右侧开始找第1对重复的数,然后将其加1,得到一个新的数

3 .  然后用这个数再从第2步开始

4 虽然把每一对重复的数都变成了不重复的,但仍然不是最小的数,需要将当前重复数后面的数变成最小的,例如,99561将99变成不重复的数,也就是100,原来的数变成了100531,但100531还需要继续变成100101,再查找重复数,把到了00,再变成101101,然后再变成101010

 

2、长度为n字符串、求字符串里最长回文子串

算法思路:

1 先在每两个相邻字符中间插入一个分隔符,当然这个分隔符要在原串中没有出现过。一般可以用‘#’分隔。这样就非常巧妙的将奇数长度回文串与偶数长度回文串统一起来考虑了

2 然后用一个辅助数组P记录以每个字符为中心的最长回文串的信息。P[id]记录的是以字符str[id]为中心的最长回文串,当以str[id]为第一个字符,这个最长回文串向右延伸了P[id]个字符。

3 从前往后扫的。那么当我们准备求P[i]的时候,i以前的P[j]我们是已经得到了的。我们用mx记在i之前的回文串中,延伸至最右端的位置。同时用id这个变量记下取得这个最优mx时的id值

4 如果 mx > i p[i] =MIN( p[2*id-i], mx-i );  // 根据回文的性质,但是如果超过了mx-i 那一部分还没有比较过,所以取最小值

  否者:p[i]=1

然后对后半部分进行遍历比较 for(; str[i+p[i]] == str[i-p[i]]; p[i]++) 跟新 mx  和 i 的值 然后循环

最后对数组P遍历即可求出最大值

 

3、数轴上从左到右有n个点、a[]0    a[]1……、给定一根长度为l绳子、求绳子最多覆盖其中几个点

数组题算法描述:

maxCover=1 ,  coverNum = 0 ,beginPos=0,endPos=1 分别表示最多覆盖点数,当前遍历开始节点和结束点

1 如果a[endPos] – a[beginPos]== l 这个是时候正好覆盖coverNum = endPos–beginPos + 1; 右移动beginPos++;endPos++;

2 如果a[endPos] – a[beginPos]> l 这个时候超过了需要回退coverNum= endPos–beginPos; 向右移动beginPos++;endPos++;

3 如果coverNUm >maxCover  更新maxCover = coverNum

4 如果a[endPos] –a[beginPos]  < L ,endPos++;

循环直到endPos <= n – 1

 

 


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值