Advertisement
Okorosso

наибольшая подстрока

Jul 7th, 2021
1,229
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.74 KB | None | 0 0
  1. #include <fstream>
  2. #include <string>
  3. #include <map>
  4.  
  5. using namespace std;
  6.  
  7. const int MAXLEN = 100000;
  8.  
  9. int sz, last;
  10.  
  11. struct state {
  12.     int len, link;
  13.     map<char, int> next;
  14. };
  15.  
  16. state st[MAXLEN * 2];
  17.  
  18. void init() {
  19.     sz = last = 0;
  20.     st[0].len = 0;
  21.     st[0].link = -1;
  22.     ++sz;
  23. }
  24.  
  25. void extend(char c) {
  26.     int cur = sz++;
  27.     st[cur].len = st[last].len + 1;
  28.     int p;
  29.     for (p = last; p != -1 && !st[p].next.count(c); p = st[p].link)
  30.         st[p].next[c] = cur;
  31.     if (p == -1)
  32.         st[cur].link = 0;
  33.     else {
  34.         int q = st[p].next[c];
  35.         if (st[p].len + 1 == st[q].len)
  36.             st[cur].link = q;
  37.         else {
  38.             int clone = sz++;
  39.             st[clone].len = st[p].len + 1;
  40.             st[clone].next = st[q].next;
  41.             st[clone].link = st[q].link;
  42.             for (; p != -1 && st[p].next[c] == q; p = st[p].link)
  43.                 st[p].next[c] = clone;
  44.             st[q].link = st[cur].link = clone;
  45.         }
  46.     }
  47.     last = cur;
  48. }
  49.  
  50.  
  51. string lcs(string s, string t) {
  52.     init();
  53.     for (int i = 0; i < (int) s.length(); ++i)
  54.         extend(s[i]);
  55.  
  56.     int v = 0, l = 0,
  57.             best = 0, bestpos = 0;
  58.     for (int i = 0; i < (int) t.length(); ++i) {
  59.         while (v && !st[v].next.count(t[i])) {
  60.             v = st[v].link;
  61.             l = st[v].len;
  62.         }
  63.         if (st[v].next.count(t[i])) {
  64.             v = st[v].next[t[i]];
  65.             ++l;
  66.         }
  67.         if (l > best)
  68.             best = l, bestpos = i;
  69.     }
  70.     return t.substr(bestpos - best + 1, best);
  71. }
  72.  
  73. int main(){
  74.     ifstream fin("common.in");
  75.     ofstream fout("common.out");
  76.  
  77.     string first, second;
  78.     fin >> first >> second;
  79.     fout << lcs(first, second);
  80. }
  81.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement