Submission #1689632


Source Code Expand

#include<bits/stdc++.h>

typedef unsigned int uint;
typedef long long ll;
typedef unsigned long long ull;
typedef double lf;
typedef long double llf;
typedef std::pair<int,int> pii;

#define xx first
#define yy second

template<typename T> inline T max(T a,T b){return a>b?a:b;}
template<typename T> inline T min(T a,T b){return a<b?a:b;}
template<typename T> inline T abs(T a){return a>0?a:-a;}
template<typename T> inline bool repr(T &a,T b){return a<b?a=b,1:0;}
template<typename T> inline bool repl(T &a,T b){return a>b?a=b,1:0;}
template<typename T> inline T gcd(T a,T b){T t;if(a<b){while(a){t=a;a=b%a;b=t;}return b;}else{while(b){t=b;b=a%b;a=t;}return a;}}
template<typename T> inline T sqr(T x){return x*x;}
#define mp(a,b) std::make_pair(a,b)
#define pb push_back
#define I inline
#define mset(a,b) memset(a,b,sizeof(a))
#define mcpy(a,b) memcpy(a,b,sizeof(a))

#define fo0(i,n) for(int i=0,i##end=n;i<i##end;i++)
#define fo1(i,n) for(int i=1,i##end=n;i<=i##end;i++)
#define fo(i,a,b) for(int i=a,i##end=b;i<=i##end;i++)
#define fd0(i,n) for(int i=(n)-1;~i;i--)
#define fd1(i,n) for(int i=n;i;i--)
#define fd(i,a,b) for(int i=a,i##end=b;i>=i##end;i--)
#define foe(i,x)for(__typeof(x.end())i=x.begin();i!=x.end();++i)

struct Cg{I char operator()(){return getchar();}};
struct Cp{I void operator()(char x){putchar(x);}};
#define OP operator
#define RT return *this;
#define RX x=0;char t=P();while((t<'0'||t>'9')&&t!='-')t=P();bool f=0;\
if(t=='-')t=P(),f=1;x=t-'0';for(t=P();t>='0'&&t<='9';t=P())x=x*10+t-'0'
#define RL if(t=='.'){lf u=0.1;for(t=P();t>='0'&&t<='9';t=P(),u*=0.1)x+=u*(t-'0');}if(f)x=-x
#define RU x=0;char t=P();while(t<'0'||t>'9')t=P();x=t-'0';for(t=P();t>='0'&&t<='9';t=P())x=x*10+t-'0'
#define TR *this,x;return x;
I bool IS(char x){return x==10||x==13||x==' ';}template<typename T>struct Fr{T P;I Fr&OP,(int&x)
{RX;if(f)x=-x;RT}I OP int(){int x;TR}I Fr&OP,(ll &x){RX;if(f)x=-x;RT}I OP ll(){ll x;TR}I Fr&OP,(char&x)
{for(x=P();IS(x);x=P());RT}I OP char(){char x;TR}I Fr&OP,(char*x){char t=P();for(;IS(t);t=P());if(~t){for(;!IS
(t)&&~t;t=P())*x++=t;}*x++=0;RT}I Fr&OP,(lf&x){RX;RL;RT}I OP lf(){lf x;TR}I Fr&OP,(llf&x){RX;RL;RT}I OP llf()
{llf x;TR}I Fr&OP,(uint&x){RU;RT}I OP uint(){uint x;TR}I Fr&OP,(ull&x){RU;RT}I OP ull(){ull x;TR}};Fr<Cg>in;
#define WI(S) if(x){if(x<0)P('-'),x=-x;char s[S],c=0;while(x)s[c++]=x%10+'0',x/=10;while(c--)P(s[c]);}else P('0')
#define WL if(y){lf t=0.5;for(int i=y;i--;)t*=0.1;if(x>=0)x+=t;else x-=t,P('-');*this,(ll)(abs(x));P('.');if(x<0)\
x=-x;while(y--){x*=10;x-=floor(x*0.1)*10;P(((int)x)%10+'0');}}else if(x>=0)*this,(ll)(x+0.5);else *this,(ll)(x-0.5);
#define WU(S) if(x){char s[S],c=0;while(x)s[c++]=x%10+'0',x/=10;while(c--)P(s[c]);}else P('0')
template<typename T>struct Fw{T P;I Fw&OP,(int x){WI(10);RT}I Fw&OP()(int x){WI(10);RT}I Fw&OP,(uint x){WU(10);RT}
I Fw&OP()(uint x){WU(10);RT}I Fw&OP,(ll x){WI(19);RT}I Fw&OP()(ll x){WI(19);RT}I Fw&OP,(ull x){WU(20);RT}I Fw&OP()
(ull x){WU(20);RT}I Fw&OP,(char x){P(x);RT}I Fw&OP()(char x){P(x);RT}I Fw&OP,(const char*x){while(*x)P(*x++);RT}
I Fw&OP()(const char*x){while(*x)P(*x++);RT}I Fw&OP()(lf x,int y){WL;RT}I Fw&OP()(llf x,int y){WL;RT}};Fw<Cp>out;

const int N=200007;

typedef std::pair<ll,ll>pll;

char s[N];
int n,f[N];
ll ans[26],h[N];

std::vector<ll>v,t;

inline ll cal(ll x)
{
	if(x<=n)return f[x];
	fo0(i,v.size())if(x<=v[i])return x-v[i]/2;
}

inline void sol(ll x,int d)
{
	if(!x)return;
	std::priority_queue<pll>q;
	q.push(mp(x-1,1));
	fd0(i,t.size())
	{
		ll sum=0;
		while(q.top().xx>=t[i])
		{
			pll u=q.top();q.pop();
			sum+=u.xx/t[i]*u.yy;
			q.push(mp(u.xx%t[i],u.yy));
		}
		if(sum)q.push(mp(t[i]-1,sum));
		//foe(j,f)out,j->xx,' ',j->yy,'\n';out,'\n';
	}
	mset(h,0);
	while(!q.empty())h[q.top().xx]+=q.top().yy,q.pop();
	fd0(i,n)h[i]+=h[i+1];
	fo0(i,n)ans[s[i+1]]+=h[i]*d;
}

int main()
{
	ll l,r;
	in,s+1,l,r;
	n=strlen(s+1);
	fo1(i,n)s[i]-=97;
	f[1]=0;
	fo(i,2,n)
	{
		int t=f[i-1];
		for(;t&&s[t+1]!=s[i];t=f[t]);
		if(s[t+1]==s[i])f[i]=t+1;
		else f[i]=0;
	}
	if(f[n]==n-1)
	{
		fo0(i,26)out,i==s[1]?r-l+1:0,' ';out,'\n';
		return 0;
	}
	v.pb(n);
	while(v.back()<r)
	{
		ll t=v.back();
		while(t*2>=v.back())t=cal(t);
		v.pb((v.back()-t)*2);
	}
	//out,'/',cal(70),'\n';
	//foe(i,v)out,*i,' ';out,'\n';
	t=v;
	foe(i,t)if(*i!=n)*i/=2;
	sol(r,1);
	sol(l-1,-1);
	fo0(i,26)out,ans[i],' ';out,'\n';
}

Submission Info

Submission Time
Task F - SS
User mcfx
Language C++14 (GCC 5.4.1)
Score 1100
Code Size 4471 Byte
Status AC
Exec Time 7 ms
Memory 2816 KB

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 7 ms 2816 KB
rnd_6_16666_4.txt AC 6 ms 2816 KB
rnd_7777_1_0.txt AC 3 ms 1920 KB
rnd_7777_1_2289.txt AC 3 ms 1920 KB
rnd_7777_1_6444.txt AC 3 ms 1920 KB
rnd_7777_9_0.txt AC 5 ms 2560 KB
rnd_7777_9_1542.txt AC 5 ms 2560 KB
rnd_7777_9_2299.txt AC 5 ms 2560 KB
rnd_77_1_0.txt AC 2 ms 1792 KB
rnd_77_1_14.txt AC 2 ms 1792 KB
rnd_77_1_2.txt AC 2 ms 1792 KB
rnd_77_9_0.txt AC 2 ms 1792 KB
rnd_77_9_11.txt AC 2 ms 1792 KB
rnd_77_9_54.txt AC 2 ms 1792 KB
rnd_7_1_0.txt AC 2 ms 1792 KB
rnd_7_1_2.txt AC 2 ms 1792 KB
rnd_7_1_3.txt AC 2 ms 1792 KB
rnd_7_9_0.txt AC 2 ms 1792 KB
rnd_7_9_1.txt AC 2 ms 1792 KB
rnd_7_9_2.txt AC 2 ms 1792 KB
rndmx_100000_1_0.txt AC 6 ms 2816 KB
sample1.txt AC 2 ms 1792 KB
sample2.txt AC 1 ms 256 KB
sample3.txt AC 2 ms 1792 KB