标签:string int Manacher len 算法 str 回文 mx 拉车
该算法可以在时间空间都为O(n),求出最大的回文子串
string longestPalindrome(string s) { string str; string ans; int start=0, end=0; str += "$#"; for (int i = 0; i < s.size(); i++) {//初始化,使用#对字符串每一个间隙都进行填充 str += s[i]; str += "#"; } str += "^";//字符串首尾加上#,^不同字符避免越界判定 int len = str.size(); int Max_len = -1;//最大的回文长度 int id;//最右边的回文串的最中间 int mx = 0;//最右边的回文串的最右界限 int p[2009] = {}; for (int i = 1; i < len; i++) { if (i < mx) {//在界限内 p[i] = min(p[2 * id - i], mx - i); } else { p[i] = 1; } while (str[i - p[i]] == str[i + p[i]]) {//扩大 p[i]++; } if (mx < i + p[i]) {//如果不是最右,更新 id = i; mx = i + p[i]; } if (p[i] - 1 > Max_len) {//记录位置 Max_len = p[i] - 1; start = i - p[i]+1; end = i + p[i]-1; } } for (int i = start; i <= end; i++) {//截取最大回文串 if (str[i] != '#') { ans += str[i]; } } return ans; } int main() { cout << longestPalindrome("babad") << endl;//bab return 0; }
标签:string,int,Manacher,len,算法,str,回文,mx,拉车 来源: https://www.cnblogs.com/whhh/p/15843880.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。