L2-008. 最长对称子串 (有个知识点没看)
思路
方法一:判断字符串的每一个子串,若是对称的,则求出它的长度即可。这种办法对每一个子串,从两头向中间判断是不是子串。总的时间复杂度为O(n^3),
下面给出时间复杂度是O(n^2)的思路。
方法二:与方法一正好相反,字符串中的每一个开始,向两边扩展,此时可分为两种情况:
(1)对称子串长度是奇数时, 以当前字符为对称轴向两边扩展比较
(2)对称子串长度是偶数时,以当前字符和它右边的字符为对称轴向两边扩展
1 #include <cstdio> 2 #include <cstring> 3 int maxsubstring(char *str) 4 { 5 int length=1,newlength,i; 6 int left,right; 7 int len=strlen(str); 8 for(i=0;i<len;i++) 9 { 10 newlength=1; //对称可能为奇数时 11 left=i-1; 12 right=i+1; 13 for(;left>=0&&right<len;left--,right++) 14 if(str[left]==str[right]) 15 newlength+=2; 16 else 17 break; 18 if(newlength>length) 19 length=newlength; 20 21 newlength=0; //对称可能为偶数时 22 left=i; 23 right=i+1; 24 for(;left>=0&&right<=len;left--,right++) 25 if(str[left]==str[right]) 26 newlength+=2; 27 else 28 break; 29 if(newlength>length) 30 length=newlength; 31 } 32 return length; 33 } 34 int main() 35 { 36 char str[1005]; 37 gets(str); 38 int ret; 39 ret=maxsubstring(str); 40 printf("%d\n",ret); 41 return 0; 42 }
网上说还有个O(n)的
上网查了下 http://www.cnblogs.com/biyeymyhjob/archive/2012/10/04/2711527.html
有时间再看看吧。。毕竟速度是遍历的快的多。。。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步