답안 #56478

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
56478 2018-07-11T12:49:07 Z ramchandra Lollipop (POI11_liz) C++14
82 / 100
2000 ms 75268 KB
#include <bits/stdc++.h>
#define in(x) ll x;cin>>x;
#define al(x) x.begin(),x.end()
#define vc vector
#define fo(i,a,b) for(ll i=a;i<b;i++)
using namespace std;
using ll = long long; // mem
int main(){
	cin.sync_with_stdio(false);
	cout.sync_with_stdio(false);
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	cout.tie(nullptr);
	in(n);in(m);
	//vc<ll> ar(2*n+50,-1);
	//vc<ll> ps(2*n+50,-1);
	//vc<ll> is(2*n+50,-1);
	const ll BIG=2e6+50;
	#define DF(zz) ll zz[BIG];fill(zz,zz+BIG,-1);
	DF(ar);
	DF(ps);
	DF(is);
	DF(ls);
	ll cnt = 0;
	ll fst = -1;
	fo(i,0,n){
		char c;cin>>c;
		bool tp = (c=='T');
		if(fst==-1 && !tp){fst = cnt;}
		ar[cnt]=i;
		ps[i]=cnt;
		cnt++; cnt+=tp;
	}
	if(fst==-1){fst = cnt;}
	ar[cnt] = n;
	ps[n] = cnt;
	ll sz = ar[fst];
	ll c[2] = {2,1};
	fo(i,ar[fst]-1,n){
		ll v = ps[i+1]-fst;
		//cout<<v<<" "<<c[v%2]<<endl;
		for(ll j = max(v,c[v%2]); j <= min((ll)(2*n),v+2*sz); j+=2){
			//assert(is[j] == -1);
			is[j] = i;
			ls[j] = ar[v+fst-j];
			//cerr<<"oh "<<j<<" "<<i<<endl;
		}
		c[v%2] = v+2*sz+2;
	}
	/*fo(i,1,sz+1){
		is[2*i] = ar[fst]-1;
	}*/
	fo(z,0,m){
		in(k);
		ll l=-1,r=-1;
	    if(fst+k<=cnt){
			if(ar[fst+k]==-1){
				l = ar[fst]+1;
				r = ar[fst+k-1];
			}
			else{
				l = ar[fst];
				r = ar[fst+k]-1;
			}
		}
		else {
			if(is[k]!=-1){
				r = is[k];
				//l = ar[ps[r+1]-k];
				l = ls[k];
			}
		}
		if(l!=-1){
			cout<<l+1<<" "<<r+1<<endl;
		}
		else {
			cout<<"NIE"<<endl;
		}
	}
}
# 결과 실행 시간 메모리 Grader output
1 Correct 53 ms 62968 KB Output is correct
2 Correct 58 ms 62968 KB Output is correct
3 Correct 57 ms 63152 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 64 ms 63152 KB Output is correct
2 Correct 64 ms 63152 KB Output is correct
3 Correct 59 ms 63152 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 51 ms 63212 KB Output is correct
2 Correct 59 ms 63296 KB Output is correct
3 Correct 115 ms 63340 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 77 ms 63340 KB Output is correct
2 Correct 82 ms 63356 KB Output is correct
3 Correct 75 ms 63356 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 96 ms 63468 KB Output is correct
2 Correct 102 ms 63468 KB Output is correct
3 Correct 262 ms 64432 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 235 ms 64432 KB Output is correct
2 Correct 1096 ms 67288 KB Output is correct
3 Correct 523 ms 67288 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 199 ms 67288 KB Output is correct
2 Correct 250 ms 67288 KB Output is correct
3 Correct 467 ms 67288 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 697 ms 67288 KB Output is correct
2 Correct 640 ms 67288 KB Output is correct
3 Correct 902 ms 67736 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1327 ms 70464 KB Output is correct
2 Correct 1302 ms 70464 KB Output is correct
3 Correct 1471 ms 71676 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1150 ms 71676 KB Output is correct
2 Correct 1745 ms 71676 KB Output is correct
3 Correct 1728 ms 71896 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2078 ms 74436 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2073 ms 75268 KB Time limit exceeded
2 Halted 0 ms 0 KB -