leetcode 214 Shortest Palindrome

lc214 Shortest Palindrome

可以将问题转化成找到原字符串的最长palindrome子串(注意,子串必须以s[0]为起始)

例如:sdserf

sds为最长palindrome子串

只需要将sds之后的子串翻转一下,补充到原字符串之前即可

fre + sdserf

 

那么如何找到最长palindrome子串呢?

使用KMP

s + “@” + reverse(s)

@的目的是保证s的每一位都与其翻转后相应位置对应,避免由于字符串长度为奇数或为偶数而产生的差别

与原版KMP算法稍微有一些区别,原版kmp表的每一位kmp[i]表示s(0~i-1)不包含i,而这里的KMP表则应该包含i,为s(0~i)

除此之外,由于我们这里只需要求kmp表而不需要考虑模式串和主串的匹配,所以不需要将kmp[0]设为-1,而是直接设为0

具体KMP的算法原理可以参见:https://www.cnblogs.com/yjiyjige/p/3263858.html

 1 class Solution {
 2     public String shortestPalindrome(String s) {
 3         String temp = s + "!" + new StringBuilder(s).reverse().toString();
 4         
 5         int[] KMP = kmp(temp);
 6         return new StringBuilder(s.substring(KMP[KMP.length-1])).reverse() + s;
 7         
 8     }
 9     private int[] kmp(String s){
10         int k=0;
11         int[] res = new int[s.length()];
12         
13         for(int i=1; i<s.length()-1; ){
14             if(s.charAt(k) == s.charAt(i)){
15                 res[i] = ++k;
16                 i++;
17             }else{
18                 if(k > 0){
19                     k = res[k-1];
20                 }else{
21                     i++;
22                 }
23             }
24         }
25         return res;
26     }
27 }

 

转载于:https://www.cnblogs.com/hwd9654/p/11042492.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/386619.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

程序员深度学习!我想谈谈关于Android面试那些事,附赠课程+题库

想要成为一名优秀的Android开发&#xff0c;你需要一份完备的知识体系&#xff0c;在这里&#xff0c;让我们一起成长为自己所想的那样~。 25%的面试官会在头5分钟内决定面试的结果60%的面试官会在头15分钟内决定面试的结果 一般来说&#xff0c;一场单面的时间在30分钟左右&…

MOSS 代替Spring Boot Admin 的服务治理工具

1.1 什么是服务治理 服务治理&#xff0c;我也称之为微服务治理&#xff0c;是指用来管理微服务的整个生命周期。包括应用的创建&#xff0c;服务名的规范&#xff0c;服务的上下线&#xff0c;服务的迁移&#xff0c;整个服务的生老病死等方方面面的治理。 1.2 Moss概述 Mo…

Django之form表单组件、cookie与session

---恢复内容开始--- Form表单组件 引例&#xff1a; 先来看一个注册的例子&#xff0c;全部用的是reg函数来实现的。 views.py文件 def reg(request):errors {username:,password:}if request.method POST:username request.POST.get(username)password request.POST.get(p…

程序员经验分享:Android高级工程师系列学习路线介绍,面试必备

前言 曾听过很多人说Android学习很简单&#xff0c;做个App就上手了&#xff0c;工作机会多&#xff0c;毕业后也比较容易找工作。这种观点可能是很多Android开发者最开始入行的原因之一。 在工作初期&#xff0c;工作主要是按照业务需求实现App页面的功能&#xff0c;按照设…

Java实现将文件或者文件夹压缩成zip

Java实现将文件或者文件夹压缩成zip 最近碰到个需要下载zip压缩包的需求&#xff0c;于是我在网上找了下别人写好的zip工具类。但找了好多篇博客&#xff0c;总是发现有bug。因此就自己来写了个工具类。 这个工具类的功能为&#xff1a; &#xff08;1&#xff09;可以压缩文件…

算法题+JVM+自定义View,隔壁都馋哭了

反思 昨晚去北京大望路阿里面试, 产生了严重的挫败感, 羞愧难当. 比不得从大学就有目标有理想, 一直在为目标努力学习技术的同学, 在大学唯一能拿得出手的就是参加了电子设计大赛, 学了点嵌入式的知识. 毕业后开始做android, 说得好听点叫做项目, 实际上就是搬代码, 真正记到…

n2n内网穿透打洞部署全过程 + nginx公网端口映射

内网穿透、打洞工具有很多&#xff0c;此前在windows上使用的是vidcc这个玩意&#xff0c;也正因为linux不支持。自此在linux尝试过一些打洞工具&#xff0c;ssh 反向代理这些&#xff0c;因为安全性不便捷等多种原因&#xff0c;最终选择了n2n。 由于初次接触n2n&#xff0c;对…

Windows下快速删除上万个文件和子目录

为什么会慢 如果直接在Windows文件管理器里删除的话&#xff08;通过菜单或者键盘Del或者ShiftDel&#xff09;&#xff0c;删除这个数量的文件需要大概10几分钟&#xff0c;具体根据文件数量目录层次不同耗时不同。这么慢是因为在删除之前系统有个准备阶段&#xff0c;在这个阶…

终于有人把安卓程序员必学知识点全整理出来了,BAT大厂面试总结

行业激烈变化时&#xff0c;恰恰是机会最多的时候 坦白讲&#xff0c;许多人骨子里害怕变化和竞争。 其实大可不必。 一来&#xff0c;怕也没用嘛。二来&#xff0c;变化越快&#xff0c;组合要素增加了&#xff0c;意味着新的工作机会越多。 就像传统媒体VS新媒体。 放在…

c#反混淆工具de4dot 一般混淆都可以解决

c#反混淆工具de4dot 一般混淆都可以解决 使用方法&#xff1a; 1、CMD 打开 De4Dot 所在文件夹 最好是以管理员身份运行CMD 2、输入 De4Dot C:\Users\muzigaiyu\Desktop\demo.exe 回车 成功后会在软件所在文件夹生成 demo-cleaned.exe 在用dotpeek 或者其他软件打开exe即可看…

餐厅点餐系统:测试与部署

项目测试与部署 1.系统测试 项目调试完成后&#xff0c;将项目打包成war包放入tomcat/wabapps文件夹&#xff0c;本机启动tomcat&#xff0c;redis缓存&#xff0c;mysql数据库等服务&#xff0c;本机访问localhost&#xff1a;8080/BookFood&#xff0c;测试系统的各个功能是否…

SpringCloud与Seata分布式事务初体验

在本篇文章中我们在SpringCloud环境下通过使用Seata来模拟用户购买商品时由于用户余额不足导致本次订单提交失败&#xff0c;来验证下在MySQL数据库内事务是否会回滚。 本章文章只涉及所需要测试的服务列表以及Seata配置部分。 用户提交订单购买商品大致分为以下几个步骤&…

想学IT的必看!今年Android面试必问的这些技术面,架构师必备技能

第一次观看我文章的朋友&#xff0c;可以关注、点赞、转发一下&#xff0c;每天分享各种干货技术和程序猿趣事 前言 职场的金三银四跳槽季又来了&#xff0c;不同的是今年比往年「冷」一些&#xff0c;形式更加严峻一些&#xff0c;大家多多少少可能都听到或看到一些信息&…

springboot集成redis使用redis作为session报错ClassNotFoundException类RememberMeServices

springboot 集成redis使用redis作为缓存&#xff0c;会报错的问题。 错误信息&#xff1a; java.lang.IllegalStateException: Error processing condition on org.springframework.boot.autoconfigure.task.TaskSchedulingAutoConfiguration.taskSchedulerat org.springframew…

阿里巴巴分布式事务利器Seata环境准备

阿里巴巴自从跟SpringCloud共同发起创建微服务开源社区时&#xff0c;开启了SpringCloud Alibaba分支&#xff0c;而且在生态内提供了一款适用于分布式应用程序&#xff08;Dubbo、SpringCloud等&#xff09;的事务框架Seata&#xff0c;该框架经过多个大版本的发布&#xff0c…

对于‘敲什么都队’自主开发的《校园服务》软件的使用体验

信1805-1 边信哲 20183694 在六月十三日我系组织的2017级软件工程交流大会中&#xff0c;我为第十一组敲什么都队’自主开发的《校园服务》软件投出了我的一票&#xff0c;在为数众多的校园服务类软件中&#xff0c;《校园服务》最吸引我的地方就是他们的软件能完成数据…

阿里P7大牛亲自教你!BAT这种大厂履历意味着什么?积累总结

金九银十过后各大网络平台都是各种面经分享&#xff0c;包括已收offer&#xff0c;或面试失败的都有&#xff0c;相信大部分人都拿到了自己心仪的大厂offer&#xff0c;不过也有没有少数没能进到自己内心向往的大厂而懊恼的&#xff0c;那么到底如何才能进大厂&#xff0c;该准…

启动mac版docker自带的k8s

最近准备好好学习下k8s&#xff0c;为了图方便&#xff0c;直接使用docker集成的k8s&#xff0c;但是网上找了一些教程但都没能一次性成功&#xff0c;只好自己从头跑一遍&#xff0c;顺手写个教程可以方便有类似需求的同学参考。 话不多说&#xff0c;直接上步骤。 1.下载doc…

yum安装mysql

在CentOS7中默认安装有MariaDB&#xff0c;这个是MySQL的分支&#xff0c;但为了需要&#xff0c;还是要在系统中安装MySQL&#xff0c;而且安装完成之后可以直接覆盖掉MariaDB。 1. 下载并安装MySQL官方的 Yum Repository 1[rootBrianZhu /]# wget -i -c http://dev.mysql.com…

springboot很多以来jar包是在外部当时候,如何打dockerfile到阿里云

首先保证springboot与各种jar包文件夹在同一目录 dockerfile如下内容 FROM frolvlad/alpine-oraclejdk8 VOLUME /usr/cloud ADD lib /lib/ ADD lib_attachment /lib_attachment/ ADD lib_bigdata /lib_bigdata/ ADD lib_bpm /lib_bpm/ ADD lib_deploy /lib_deploy/ ADD lib_el…