結果
問題 | No.2858 Make a Palindrome |
ユーザー | 0214sh7 |
提出日時 | 2024-08-25 15:44:18 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 6,372 bytes |
コンパイル時間 | 2,727 ms |
コンパイル使用メモリ | 218,096 KB |
実行使用メモリ | 33,260 KB |
最終ジャッジ日時 | 2024-08-25 15:44:34 |
合計ジャッジ時間 | 15,070 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2,170 ms
6,812 KB |
testcase_01 | AC | 459 ms
6,944 KB |
testcase_02 | AC | 444 ms
6,944 KB |
testcase_03 | AC | 449 ms
6,944 KB |
testcase_04 | AC | 475 ms
6,940 KB |
testcase_05 | AC | 366 ms
6,940 KB |
testcase_06 | WA | - |
testcase_07 | WA | - |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | AC | 281 ms
6,940 KB |
testcase_14 | WA | - |
testcase_15 | AC | 88 ms
6,940 KB |
testcase_16 | AC | 83 ms
6,944 KB |
testcase_17 | AC | 90 ms
6,940 KB |
testcase_18 | AC | 85 ms
6,940 KB |
testcase_19 | AC | 88 ms
6,944 KB |
testcase_20 | AC | 78 ms
29,336 KB |
testcase_21 | AC | 77 ms
30,140 KB |
testcase_22 | AC | 47 ms
17,344 KB |
testcase_23 | AC | 95 ms
30,732 KB |
testcase_24 | AC | 63 ms
26,384 KB |
testcase_25 | AC | 61 ms
23,508 KB |
testcase_26 | AC | 72 ms
23,336 KB |
testcase_27 | AC | 88 ms
32,752 KB |
testcase_28 | AC | 73 ms
24,828 KB |
testcase_29 | AC | 103 ms
31,904 KB |
testcase_30 | AC | 86 ms
33,136 KB |
testcase_31 | AC | 88 ms
33,096 KB |
testcase_32 | AC | 82 ms
33,248 KB |
testcase_33 | AC | 87 ms
33,132 KB |
testcase_34 | AC | 89 ms
33,140 KB |
testcase_35 | AC | 86 ms
33,260 KB |
testcase_36 | AC | 81 ms
33,100 KB |
testcase_37 | AC | 84 ms
33,136 KB |
testcase_38 | AC | 87 ms
33,136 KB |
testcase_39 | AC | 84 ms
33,188 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef long double ld; typedef pair<ll,ll> PP; // #define MOD 1000000007 #define MOD 998244353 #define INF 2305843009213693951 //#define INF 810114514 #define PI 3.141592653589 #define setdouble setprecision #define REP(i,n) for(ll i=0;i<(n);++i) #define OREP(i,n) for(ll i=1;i<=(n);++i) #define RREP(i,n) for(ll i=(n)-1;i>=0;--i) #define ORREP(i,n) for(ll i=(n);i>=1;--i) #define rep(i,a,b) for(ll i=(a);i<=(b);++i) #define ALL(v) (v).begin(), (v).end() #define GOODBYE do { cout << "-1" << endl; return 0; } while (false) #define MM <<" "<< #define Endl endl #define debug true #define debug2 false class rollinghash{ // Copyright (c) 2023 0214sh7 // https://github.com/0214sh7/library/ private: static constexpr long long mod = (1LL << 61)-1; std::vector<long long> Base = {12345,10000000}; std::vector<long long> BaseInv; std::vector<std::vector<long long>> BaseInvExp; static constexpr long long h = 100; long long product(long long a,long long b){ static constexpr long long m = 1LL << 31; long long a1 = a/m,a2 = a%m; long long b1 = b/m,b2 = b%m; long long r = 0 , s; r = (r + 2*a1*b1) % mod; s = (a1*b2 + b1*a2) % mod; long long s1 = s/m,s2 = s%m; s = (2*s1+m*s2) % mod; r = (r + s) % mod; r = (r + a2*b2) % mod; return r; } long long power(long long b,long long e){ long long r=1; while(e){ if(e&1){ r=product(r,b)%mod; } b=product(b,b)%mod; e >>=1; } return r; } public: std::vector<long long> S; std::vector<std::vector<long long>> H,Hsum; void init(std::vector<long long> cs){ S=cs; int n=S.size(); BaseInv.resize(Base.size()); BaseInvExp.resize(Base.size()); H.resize(Base.size()); Hsum.resize(Base.size()); for(int i=0;i<(int)Base.size();i++){ BaseInvExp[i].assign(n+1,1); H[i].assign(n+1,0); Hsum[i].assign(n+1,0); } //逆元 for(int i=0;i<(int)Base.size();i++){ BaseInv[i]=power(Base[i],mod-2); } for(int i=0;i<(int)Base.size();i++){ for(int j=0;j<n;j++){ BaseInvExp[i][j+1] = product(BaseInvExp[i][j],BaseInv[i]); } } //本体 for(int i=0;i<(int)Base.size();i++){ long long b=1; for(int j=0;j<n;j++){ H[i][j]=product(b,S[j]+h); b=product(b,Base[i]); } } //累積和 for(int i=0;i<(int)Base.size();i++){ for(int j=0;j<n;j++){ Hsum[i][j+1]=(Hsum[i][j]+H[i][j])%mod; } } } rollinghash(std::vector<long long> C){ init(C); } std::vector<long long> get(int l,int r){ std::vector<long long> R(Base.size()); for(int i=0;i<(int)Base.size();i++){ long long g = (Hsum[i][r]-Hsum[i][l]+mod)%mod; g=product(g,BaseInvExp[i][l]); R[i] = g; } return R; } std::vector<long long> instant(std::vector<long long> P){ std::vector<long long> R; for(int i=0;i<(int)Base.size();i++){ long long r = 0, b = 1; for(int j=0;j<(int)P.size();j++){ r = (r+product(b,P[j]+h))%mod; b = product(b,Base[i]); } R.push_back(r); } return R; } std::vector<long long> connect(std::vector<long long> P,long long ps,std::vector<long long> Q,long long qs){ std::vector<long long> R; for(int i=0;i<(int)Base.size();i++){ long long r = (product(Q[i],power(Base[i],ps))+P[i])%mod; R.push_back(r); } return R; assert(qs==qs); } }; ll Manacher(string _s){ int n = _s.size(); //'#'の追加 string s(2 * n + 1, '#'); for (int i = 0; i < n; i++) s[2 * i + 1] = _s[i]; n = 2 * n + 1; // cout << "? " << s << endl; vector<int> rad(n); int c = 0, r = 0; while (c < n) { // cを中心に同じ文字がどこまで連続するか while (0 <= c - r && c + r < n && s[c - r] == s[c + r]) r++; rad[c] = r; //回文の長さに応じて利用可能な範囲を確認しつつメモ int k = 1; while (0 <= c - k && k + rad[c - k] < r) { rad[c + k] = rad[c - k]; k++; } //すでに計算が終わった分だけ中心と探索半径をずらす c += k; r -= k; } //'#'分の補正 // for (int i = 0; i < n; i++) { // if (i % 2 == 0) // rad[i] = (rad[i] - 1) / 2; // else // rad[i] /= 2; // } // REP(i,rad.size()){cout << rad[i] << " ";}cout << endl; ll Lmax = 0; REP(i,rad.size()){ if(i%2==0){ Lmax = max(Lmax,(ll)rad[i]-1); }else{ Lmax = max(Lmax,(ll)rad[i]-1); } } // cout << "! " << Lmax << endl; return Lmax; } void solve(){ ll N,X; cin >> N >> X; string S; cin >> S; vector<ll> Ss(N); REP(i,N){Ss[i] = S[i];} rollinghash rolS(Ss); reverse(ALL(Ss)); rollinghash rolR(Ss); // 1個のなかにあるか? ll L = Manacher(S); if(L >= X){ cout << 1 << endl; return; } // 2個のなかにあるか? string T = S+S; L = Manacher(T); if(L >= X){ cout << 2 << endl; return; } // 回文か? if(rolS.get(0,N)==rolR.get(0,N)){ cout << (X+N-1)/N << endl; return; } // 2-回文か? REP(i,N-1){ if(rolS.get(0,i+1)==rolR.get(N-i-1,N) && rolS.get(i+1,N)==rolR.get(0,N-i-1)){ ll c = max(i+1,N-i-1); ll Ans = 1, t = max(0ll,X-c); Ans += (t+N-1)/N; cout << Ans << endl; return; } } cout << -1 << endl; return; } int main(void){ //cin.tie(nullptr); //ios::sync_with_stdio(false); ll T; cin >> T; REP(_,T){solve();} return 0; }