Submission #231370

# Submission time Handle Problem Language Result Execution time Memory
231370 2020-05-13T12:45:05 Z Fasho Crayfish scrivener (IOI12_scrivener) C++14
60 / 100
1000 ms 14840 KB
#include <bits/stdc++.h>
#define N 1000005
#define ll long long int 	
#define MP make_pair
#define pb push_back
#define ppb pop_back
#define sp " "
#define endl "\n"
#define fi first
#define se second
#define ii pair<int,int>
#define lli pair<ll,ll>
#define fast cin.tie(0);cout.tie(0);ios_base::sync_with_stdio(false)
#define fast2 freopen ("badhair.gir","r",stdin);freopen ("badhair.cik","w",stdout);
#define mod 1000000007
#define fs(x,y) for(ll i=1;i<=y;i++) cin>>x[i]
#define fo(i,x,y) for(ll i=x;i<=y;i++)
#define INF 1000000000005
#define ull unsigned long long int
using namespace std;


char last,flag=1;

ll dad[N],cnt;

char s[N];
vector<char> v;


ll find(int x)
{
	if(dad[x]==x)
		return x;
	return dad[x]=find(dad[x]);
}

void unite(int x,int y)
{
	int dx=find(x);
	int dy=find(y);
	dad[dy]=dx;
}

void Init() 
{

}


void TypeLetter(char L) {

	flag=0;

	s[++cnt]=L;
	dad[cnt]=cnt;
  

  last = L;


}

void UndoCommands(int U) 
{
	flag=0;
	cnt++;
	dad[cnt]=cnt;
	unite(cnt-U-1,cnt);
}

char GetLetter(int P) {
	ll x=cnt;
	if(flag==1)
		return v[P];
	flag=1;
	v.clear();
	while(x>0)
	{
		x=find(x);
		// cerr<<"[d]"<<sp<<x<<endl;
		v.pb(s[x]);
		x--;
	}

	reverse(v.begin(), v.end());
	return  v[P];
  // return last;

}
# Verdict Execution time Memory Grader output
1 Correct 4 ms 384 KB Output is correct
2 Correct 4 ms 384 KB Output is correct
3 Correct 4 ms 384 KB Output is correct
4 Correct 4 ms 384 KB Output is correct
5 Correct 5 ms 256 KB Output is correct
6 Correct 5 ms 384 KB Output is correct
7 Correct 4 ms 384 KB Output is correct
8 Correct 4 ms 384 KB Output is correct
9 Correct 4 ms 384 KB Output is correct
10 Correct 4 ms 384 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 4 ms 384 KB Output is correct
2 Correct 4 ms 384 KB Output is correct
3 Correct 5 ms 384 KB Output is correct
4 Correct 4 ms 384 KB Output is correct
5 Correct 4 ms 384 KB Output is correct
6 Correct 5 ms 384 KB Output is correct
7 Correct 4 ms 384 KB Output is correct
8 Correct 4 ms 384 KB Output is correct
9 Correct 4 ms 384 KB Output is correct
10 Correct 4 ms 384 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 5 ms 384 KB Output is correct
2 Correct 8 ms 384 KB Output is correct
3 Correct 6 ms 384 KB Output is correct
4 Correct 5 ms 384 KB Output is correct
5 Correct 7 ms 384 KB Output is correct
6 Correct 6 ms 384 KB Output is correct
7 Correct 6 ms 384 KB Output is correct
8 Correct 8 ms 384 KB Output is correct
9 Correct 12 ms 384 KB Output is correct
10 Correct 6 ms 384 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 140 ms 7672 KB Output is correct
2 Correct 159 ms 12664 KB Output is correct
3 Correct 172 ms 13128 KB Output is correct
4 Correct 243 ms 14840 KB Output is correct
5 Correct 194 ms 12920 KB Output is correct
6 Correct 172 ms 13560 KB Output is correct
7 Correct 251 ms 14196 KB Output is correct
8 Correct 228 ms 14452 KB Output is correct
9 Correct 173 ms 13300 KB Output is correct
10 Correct 179 ms 13176 KB Output is correct
# Verdict Execution time Memory Grader output
1 Execution timed out 1085 ms 1280 KB Time limit exceeded
2 Halted 0 ms 0 KB -