QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#311564#8129. Binary SequenceKevin5307AC ✓43ms11188kbC++231.5kb2024-01-22 15:16:192024-01-22 15:16:21

Judging History

你现在查看的是最新测评结果

  • [2024-01-22 15:16:21]
  • 评测
  • 测评结果:AC
  • 用时:43ms
  • 内存:11188kb
  • [2024-01-22 15:16:19]
  • 提交

answer

//Author: Kevin
#include<bits/stdc++.h>
//#pragma GCC optimize("O2")
using namespace std;
#define ll long long
#define ull unsigned ll
#define pb emplace_back
#define mp make_pair
#define ALL(x) (x).begin(),(x).end()
#define rALL(x) (x).rbegin(),(x).rend()
#define srt(x) sort(ALL(x))
#define rev(x) reverse(ALL(x))
#define rsrt(x) sort(rALL(x))
#define sz(x) (int)(x.size())
#define inf 0x3f3f3f3f
#define pii pair<int,int>
#define lb(v,x) (int)(lower_bound(ALL(v),x)-v.begin())
#define ub(v,x) (int)(upper_bound(ALL(v),x)-v.begin())
#define uni(v) v.resize(unique(ALL(v))-v.begin())
#define longer __int128_t
void die(string S){puts(S.c_str());exit(0);}
string f(string s)
{
	string ans;
	for(int i=0;i<sz(s);)
	{
		int j=i;
		while(j<sz(s)&&s[i]==s[j]) j++;
		int cnt=j-i;
		string tmp;
		while(cnt)
		{
			tmp+=(char)(48^(cnt&1));
			cnt>>=1;
		}
		rev(tmp);
		ans+=tmp;
		ans+=s[i];
		i=j;
	}
	return ans;
}
string s[1010];
int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	s[1]="1";
	int flag=0;
	int mx=1;
	for(int i=2;flag<3;i++)
	{
		s[i]=f(s[i-1]);
		if(sz(s[i])>1e6)
			flag|=(1<<(i&1));
		mx=i;
	}
	for(int i=1;i<=mx;i++)
		rev(s[i]);
	int t;
	cin>>t;
	while(t--)
	{
		ll n;
		int m;
		cin>>n>>m;
		if(n<=mx)
		{
			if(m<sz(s[n]))
				cout<<s[n][m]<<'\n';
			else
				cout<<"0\n";
		}
		else
		{
			int p=mx;
			while((n-p)%2) p--;
			cout<<s[p][m]<<'\n';
		}
	}
	return 0;
}

这程序好像有点Bug,我给组数据试试?

详细

Test #1:

score: 100
Accepted
time: 25ms
memory: 11096kb

input:

10
4 0
4 1
4 2
4 3
4 4
4 5
4 6
6 3
6 7
118999881999119725 3

output:

1
1
0
1
1
1
0
1
1
0

result:

ok 10 numbers

Test #2:

score: 0
Accepted
time: 22ms
memory: 10956kb

input:

10
28 69772
10 7908
4 3198
4 85913
14 52729
3 20445
9 88912
17 23743
25 37356
2 97697

output:

0
0
0
0
0
0
0
0
0
0

result:

ok 10 numbers

Test #3:

score: 0
Accepted
time: 25ms
memory: 11132kb

input:

100
29 110358
18 13645
18 590344
36 550462
11 133055
8 769352
11 265432
7 158530
12 29189
2 830361
11 584395
31 693707
7 879812
19 25069
21 616926
3 85158
31 675739
17 118385
24 315535
29 59615
10 33445
17 609235
8 738138
20 209540
4 287616
32 522302
26 959741
5 453537
27 74313
28 296289
28 857972
2...

output:

0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
1
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
1
0
0
0
0
1
0
0
0
0
0
1
0
1
0
1
0
1
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
1
0
0

result:

ok 100 numbers

Test #4:

score: 0
Accepted
time: 43ms
memory: 11188kb

input:

100000
702433635413308636 962533
864089450531108488 538792
262747333715821506 454514
859830947243984718 105219
365621373252206174 447331
890829905503831899 507146
116987306031929573 154370
157986473366693144 364746
502917586764426513 49981
874588963478161584 594867
467219058104100510 790503
11034861...

output:

1
1
1
1
1
1
1
0
1
0
1
0
1
1
1
1
0
1
1
1
1
1
0
1
0
0
0
0
1
1
1
0
0
1
1
0
0
1
0
1
1
1
1
0
0
0
0
1
1
0
0
1
0
0
1
0
1
1
1
1
1
1
1
0
1
1
1
0
0
0
1
1
1
0
1
1
1
1
1
1
0
1
0
1
1
1
0
0
0
1
0
0
1
0
1
1
1
1
1
1
0
0
0
0
0
0
0
1
0
0
1
0
1
0
1
0
1
1
0
1
1
0
1
0
0
0
1
1
0
1
1
0
0
1
1
1
1
1
0
0
0
0
0
0
1
1
1
0
0
1
...

result:

ok 100000 numbers

Extra Test:

score: 0
Extra Test Passed