给定一个字符串,求这个字符串的最大回文数

给定一个字符串,求这个字符串的最大回文数

ID:30519246

大小:142.68 KB

页数:6页

时间:2018-12-31

给定一个字符串,求这个字符串的最大回文数_第1页
给定一个字符串,求这个字符串的最大回文数_第2页
给定一个字符串,求这个字符串的最大回文数_第3页
给定一个字符串,求这个字符串的最大回文数_第4页
给定一个字符串,求这个字符串的最大回文数_第5页
资源描述:

《给定一个字符串,求这个字符串的最大回文数》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、题目:回文判断是一类典型的问题,尤其是与字符串结合后呈现出多姿多彩,在实际应用中比较广泛,下面介绍几个回文的问题。首先我们要介绍一个什么叫回文数:回文,就是指一个字符串顺着读和反着读都是一样的字符串,例如madam,你我你,我爱我等等一些列的字符串1、首先来判断一下一个字符串是否是回文字符串:[java]viewplaincopyprint?1publicintpalindromeNumber(Strings,intlow,inthigh){2if(low==high)3return1;4elseif(low

2、gh)&&(high-low)==1)//防止出现abba等情况6return1;7if(s.charAt(low)==s.charAt(high)&&(high-low)!=1)//这是类似aba的情况8returnpalindromeNumber(s,low+1,high-1);9else10return0;11}else12return0;13}上面的这个方法,如果输入的字符串是回文字符串的话,则输出1,如果不是的话,输出0,2、已经明白了如何判断一个字符串是否是回文数,接下来我们就要求出一个给定字符串中最大的回文数是多少,就是把这个回文数的长度打出来[java]viewpl

3、aincopyprint?14packageprogrammer;1516importjava.util.Scanner;1718/*19*回文判断是一类典型的问题,尤其是与字符串结合后呈现出多姿多彩,在实际中使用也20*比较广泛,而且也是面试题中的常客,所以本文就结合几个典型的例子来体味下回文之趣。21*回文,英文palindrome,指一个顺着读和反过来读都一样的字符串,比如madam、22*我爱我,这样的短句在智力性、趣味性和艺术性上都颇有特色,中国历史上还有很多1*有趣的回文诗呢2*/3publicclassPalindromeNumber{45publicintpalin

4、dromeNumber(Strings,intlow,inthigh){6if(low==high)7return1;8elseif(low

5、们使用了枚举的方法,但是这种方法的时间复杂度还是很大的,浪费了很多不必要的时间和判断,比如当判断21*子串不是回文时,就不必要再判断包含本子串的父串了22*/23publicintmaxPalindrome1(Strings){24intlen=0,max=0;25for(inti=0;i=i;j--){27if(palindromeNumber(s,i,j)==1){28len=j-i+1;29}30if(max

6、blicstaticvoidmain(String[]args){38Scannersc=newScanner(System.in);39Strings=sc.nextLine();40System.out.println(newPalindromeNumber().palindromeNumber(s,0,41s.length()-1));42System.out.println(newPalindromeNumber().maxPalindrome1(s));43}1}上面的思想也十分简单,就是逐个遍历,显然这是十分耗费时间的,时间复杂度为O(n*n*n),因为还要判断这个是否

7、是回文数,所以比较浪费时间。接下来我们提供一种比较有建设性的方法。3、我们知道回文数是正着读和反着读是一样的,就是说对于一个给定的字符串,如果我们将这个字符串逆置的话,我们就会发现两个字符串有一个最长的连续相同的子序列,则这个连续的最长的共同子序列就是我们要求的回文数,例如:abcabcba,反过来就是abcbacba,显然我们发现两个字符串连续的最长的共同子序列就是abcba,而abcba就是我们索要求的最长的回文数。下面是这个源代码:[java]viewplain

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。