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
AC × 3
AC × 24
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