[leetcode]Longest Palindromic Substring

题目链接:https://leetcode.com/problems/longest-palindromic-substring/

输出最长的回文串

 

复制代码
 1 class Solution {
 2 public:
 3     int pre[22222];
 4     char x[22222];
 5     char str[22222];
 6 
 7     int min(int x, int y) {
 8         return x < y ? x : y;
 9     }
10 
11     int init(char *str, char *x) {
12         int len = strlen(x);
13         str[0] = '$';
14         for (int i = 0; i <= len; i++) {
15             str[2 * i + 1] = '#';
16             str[2 * i + 2] = x[i];
17         }
18         len = 2 * len + 2;
19         str[len] = 0;
20         return len;
21     }
22     void manacher(int *pre, char *str, int len) {
23         int id = 0;
24         int mx = 0;
25         for (int i = 1; i < len; i++) {
26             pre[i] = mx > i ? min(pre[2 * id - i], mx - i) : 1;
27             while (str[i + pre[i]] == str[i - pre[i]])   pre[i]++;
28             if (pre[i] + i > mx) {
29                 id = i;
30                 mx = pre[id] + id;
31             }
32         }
33     }
34     string longestPalindrome(string s) {
35         memset(pre, 0, sizeof(pre));
36         memset(str, 0, sizeof(str));
37         int len = init(str, const_cast<char*>(s.data()));
38         manacher(pre, str, len);
39         int fuck = 1, pos = 0;
40         for (int i = 0; i < len; i++) {
41             if (fuck < pre[i]) {
42                 fuck = pre[i];
43                 pos = i;
44             }
45         }
46         pos--;
47         fuck--;
48         string ans;
49         for (int i = pos - fuck + 1; i <= pos + fuck + 1; i++) {
50             if (i % 2 == 0) {
51                 ans.push_back(str[i]);
52             }
53         }
54         return ans;
55     }
56 };
复制代码

 

posted @   Kirai  阅读(212)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示