結果
問題 | No.465 PPPPPPPPPPPPPPPPAPPPPPPPP |
ユーザー | chaemon |
提出日時 | 2016-12-15 23:28:36 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 5,045 bytes |
コンパイル時間 | 999 ms |
コンパイル使用メモリ | 95,176 KB |
実行使用メモリ | 101,888 KB |
最終ジャッジ日時 | 2024-11-30 09:00:34 |
合計ジャッジ時間 | 20,647 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | WA | - |
testcase_01 | WA | - |
testcase_02 | WA | - |
testcase_03 | WA | - |
testcase_04 | WA | - |
testcase_05 | WA | - |
testcase_06 | WA | - |
testcase_07 | WA | - |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | WA | - |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | WA | - |
testcase_18 | WA | - |
testcase_19 | WA | - |
testcase_20 | WA | - |
testcase_21 | WA | - |
32_ratsliveonnoevilstar.txt | WA | - |
ソースコード
// #includes {{{ #include <algorithm> #include <numeric> #include <iostream> #include <string> #include <vector> #include <queue> #include <list> #include <deque> #include <stack> #include <set> #include <map> #include <cstdio> #include <cstdlib> #include <cassert> #include <cstring> #include <cmath> using namespace std; // }}} // pre-written code {{{ #define REP(i,n) for(int i=0;i<(int)(n);++i) #define RREP(i,a,b) for(int i=(int)(a);i<(int)(b);++i) #define FOR(i,c) for(__typeof((c).begin()) i=(c).begin();i!=(c).end();++i) #define LET(x,a) __typeof(a) x(a) //#define IFOR(i,it,c) for(__typeof((c).begin())it=(c).begin();it!=(c).end();++it,++i) #define ALL(c) (c).begin(), (c).end() #define MP make_pair #define EXIST(e,s) ((s).find(e)!=(s).end()) #define RESET(a) memset((a),0,sizeof(a)) #define SET(a) memset((a),-1,sizeof(a)) #define PB push_back #define DEC(it,command) __typeof(command) it=command //debug #define dump(x) cerr << #x << " = " << (x) << endl; #define debug(x) cerr << #x << " = " << (x) << " (L" << __LINE__ << ")" << " " << __FILE__ << endl; #define debug2(x) cerr << #x << " = [";REP(__ind,(x).size()){cerr << (x)[__ind] << ", ";}cerr << "] (L" << __LINE__ << ")" << endl; const int INF=0x3f3f3f3f; typedef long long Int; typedef unsigned long long uInt; #ifdef __MINGW32__ typedef double rn; #else typedef long double rn; #endif typedef pair<int,int> pii; /* #ifdef MYDEBUG #include"debug.h" #include"print.h" #endif */ // }}} //{{{ Suffix Array //{{{ for DEBUG void writeSuffix(char *t,int i){ cout<<(t+i)<<"$"<<endl; } //}}} struct SuffixArray{ char *t; int n,N; int *sa,*b,*lcp,*rmq; SuffixArray(char *t):t(t){ n=strlen(t);N=n+1; } ~SuffixArray(){ if(sa)delete(sa); if(b)delete(b); if(lcp)delete(lcp); if(rmq)delete(rmq); } void builds(){ buildSA();buildLCP();buildRMQ(); } //{{{ Larsson-Sadakane's Suffix array Construction: O(n (log n)^2) struct SAComp { const int h, *g; SAComp(int h, int* g) : h(h), g(g) {} bool operator() (int a, int b) { return a == b ? false : g[a] != g[b] ? g[a] < g[b] : g[a+h] < g[b+h]; } }; void buildSA() { sa=new int[n+1];b=new int[n+1]; int g[n+1]; REP(i,n+1) sa[i] = i, g[i] = t[i]; b[0] = 0; b[n] = 0; sort(sa, sa+n+1, SAComp(0, g)); for(int h = 1; b[n] != n ; h *= 2) { SAComp comp(h, g); sort(sa, sa+n+1, comp); REP(i, n) b[i+1] = b[i] + comp(sa[i], sa[i+1]); REP(i, n+1) g[sa[i]] = b[i]; } REP(i, n+1) b[sa[i]] = i; } //}}} //{{{ Naive matching O(m log n) int find(char *t, int n, char *p, int m, int *sa) { int a = 0, b = n; while (a < b) { int c = (a + b) / 2; if (strncmp(t+sa[c], p, m) < 0) a = c+1; else b = c; } return strncmp(t+sa[a], p, m) == 0 ? sa[a] : -1; } //}}} //{{{ Kasai-Lee-Arimura-Arikawa-Park's simple LCP computation: O(n) void buildLCP() { lcp=new int[n+1]; int h = 0; REP(i, n+1) { if (b[i]){ for (int j = sa[b[i]-1]; j+h<n && i+h<n && t[j+h] == t[i+h]; ++h); lcp[b[i]] = h; } else lcp[b[i]] = -1; if (h > 0) --h; } } //}}} //{{{ call RMQ = buildRMQ(lcp, n+1) void buildRMQ() { int logn = 1; for (int k = 1; k < N; k *= 2) ++logn; rmq=new int[N*logn]; int *b = rmq; copy(lcp, lcp+N, b); for (int k = 1; k < N; k *= 2) { copy(b, b+N, b+N); b += N; REP(i, N-k) b[i] = min(b[i], b[i+k]); } } //}}} //{{{ inner LCP computation with RMQ: O(1) int minimum(int x, int y) { x++; int z = y - x, k = 0, e = 1, s; // y - x >= e = 2^k 縺ェ繧区怙螟ァ k s = ( (z & 0xffff0000) != 0 ) << 4; z >>= s; e <<= s; k |= s; s = ( (z & 0x0000ff00) != 0 ) << 3; z >>= s; e <<= s; k |= s; s = ( (z & 0x000000f0) != 0 ) << 2; z >>= s; e <<= s; k |= s; s = ( (z & 0x0000000c) != 0 ) << 1; z >>= s; e <<= s; k |= s; s = ( (z & 0x00000002) != 0 ) << 0; z >>= s; e <<= s; k |= s; return min( rmq[x+N*k], rmq[y+N*k-e+1] ); } //}}} //{{{ outer LCP computation: O(m - o) int computeLCP(char *t, int n, char *p, int m, int o, int k) { int i = o; for (; i < m && k+i < n && p[i] == t[k+i]; ++i); return i; } //}}} //{{{ Mamber-Myers's O(m + log n) string matching with LCP/RMQ #define COMP(h, k) (h == m || (k+h<n && p[h]<t[k+h])) int find(char *p, int m) { int l = 0, lh = 0, r = n, rh = computeLCP(t,N,p,m,0,sa[n]); if (!COMP(rh, sa[r])) return -1; for (int k = (l+r)/2; l+1 < r; k = (l+r)/2) { int A = minimum(l, k), B = minimum(k, r); if (A >= B) { if (lh < A) l = k; else if (lh > A) r = k, rh = A; else { int i = computeLCP(t, N, p, m, A, sa[k]); if (COMP(i, sa[k])) r = k, rh = i; else l = k, lh = i; } } else { if (rh < B) r = k; else if (rh > B) l = k, lh = B; else { int i = computeLCP(t, N, p, m, B, sa[k]); if (COMP(i, sa[k])) r = k, rh = i; else l = k, lh = i; } } } return rh == m ? sa[r] : -1; } //}}} }; //}}} uInt p = 137; char S[1000010]; int main(){ cin>>S; int n = strlen(S); S[n] = 'A'; for(int i=0;i<n;i++){ S[n+1+i] = S[n-1-i]; } S[n+1+n] = '\0'; SuffixArray sa(S); sa.builds(); return 0; }