Submission #1870998
Source Code Expand
#include <algorithm> #include <iostream> #include <cstring> #include <cstdio> #include <cmath> using namespace std; typedef long long s64; const int MaxN = 200000; const int MaxM = MaxN / 2; const int NLet = 26; int n; char s[MaxN + 2]; int sum[MaxM + 1][NLet]; int fail[MaxM + 1]; int cir_l = 0; inline void build_fail() { int k = 0; for (int i = 2; i <= n; ++i) { while (k && s[k + 1] != s[i]) k = fail[k]; fail[i] = (k += s[k + 1] == s[i]); } } s64 solve(s64 l, int c) { s64 res = 0; while (l > n) { s64 nl = cir_l, nr = n; s64 sl = sum[cir_l][c], sr = sum[n][c]; while (l >= nl + nr) { nr += nl, nl = nr - nl; sr += sl, sl = sr - sl; } l -= nr, res += sr; } return res + sum[l][c]; } int main() { scanf("%s", s + 1); n = strlen(s + 1) / 2; s[n + 1] = '\0'; for (int i = 1; i <= n; ++i) { for (int c = 0; c < NLet; ++c) sum[i][c] = sum[i - 1][c]; ++sum[i][s[i] - 'a']; } build_fail(); cir_l = n - fail[n]; s64 l, r; cin >> l >> r; for (int c = 0; c < NLet; ++c) cout << solve(r, c) - solve(l - 1, c) << ' '; cout << endl; return 0; }
Submission Info
Submission Time | |
---|---|
Task | F - SS |
User | InvUsr |
Language | C++14 (GCC 5.4.1) |
Score | 1100 |
Code Size | 1188 Byte |
Status | AC |
Exec Time | 8 ms |
Memory | 11008 KB |
Compile Error
./Main.cpp: In function ‘int main()’: ./Main.cpp:56:20: warning: ignoring return value of ‘int scanf(const char*, ...)’, declared with attribute warn_unused_result [-Wunused-result] scanf("%s", s + 1); ^
Judge Result
Set Name | Sample | All | ||||
---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 1100 / 1100 | ||||
Status |
|
|
Set Name | Test Cases |
---|---|
Sample | sample1.txt, sample2.txt, sample3.txt |
All | mx_100000_1_0.txt, rnd_6_16666_4.txt, rnd_7777_1_0.txt, rnd_7777_1_2289.txt, rnd_7777_1_6444.txt, rnd_7777_9_0.txt, rnd_7777_9_1542.txt, rnd_7777_9_2299.txt, rnd_77_1_0.txt, rnd_77_1_14.txt, rnd_77_1_2.txt, rnd_77_9_0.txt, rnd_77_9_11.txt, rnd_77_9_54.txt, rnd_7_1_0.txt, rnd_7_1_2.txt, rnd_7_1_3.txt, rnd_7_9_0.txt, rnd_7_9_1.txt, rnd_7_9_2.txt, rndmx_100000_1_0.txt, sample1.txt, sample2.txt, sample3.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
mx_100000_1_0.txt | AC | 8 ms | 11008 KB |
rnd_6_16666_4.txt | AC | 7 ms | 11008 KB |
rnd_7777_1_0.txt | AC | 2 ms | 1152 KB |
rnd_7777_1_2289.txt | AC | 2 ms | 1280 KB |
rnd_7777_1_6444.txt | AC | 2 ms | 1792 KB |
rnd_7777_9_0.txt | AC | 6 ms | 8448 KB |
rnd_7777_9_1542.txt | AC | 6 ms | 8448 KB |
rnd_7777_9_2299.txt | AC | 6 ms | 8448 KB |
rnd_77_1_0.txt | AC | 1 ms | 256 KB |
rnd_77_1_14.txt | AC | 1 ms | 256 KB |
rnd_77_1_2.txt | AC | 1 ms | 256 KB |
rnd_77_9_0.txt | AC | 1 ms | 384 KB |
rnd_77_9_11.txt | AC | 1 ms | 384 KB |
rnd_77_9_54.txt | AC | 1 ms | 384 KB |
rnd_7_1_0.txt | AC | 1 ms | 256 KB |
rnd_7_1_2.txt | AC | 1 ms | 256 KB |
rnd_7_1_3.txt | AC | 1 ms | 256 KB |
rnd_7_9_0.txt | AC | 1 ms | 256 KB |
rnd_7_9_1.txt | AC | 1 ms | 256 KB |
rnd_7_9_2.txt | AC | 1 ms | 256 KB |
rndmx_100000_1_0.txt | AC | 7 ms | 11008 KB |
sample1.txt | AC | 1 ms | 256 KB |
sample2.txt | AC | 1 ms | 256 KB |
sample3.txt | AC | 1 ms | 256 KB |