QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#357705#8129. Binary Sequencesquishybanana#AC ✓188ms5032kbC++231.2kb2024-03-19 08:30:282024-03-19 08:30:28

Judging History

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

  • [2024-03-19 08:30:28]
  • 评测
  • 测评结果:AC
  • 用时:188ms
  • 内存:5032kb
  • [2024-03-19 08:30:28]
  • 提交

answer

#include <iostream>
#include <vector>
using namespace std;
using ll = long long;
const int mn = 1e6;
vector<vector<bool>> vals;

void append(vector<bool> &x, int t) {
	vector<bool> cur;
	while (t) {
		cur.push_back(t&1);
		t/=2;
	}
	while (cur.size()) {
		x.push_back(cur.back());
		cur.pop_back();
	}
}

vector<bool> iter(const vector<bool> &val) {
	vector<bool> out;
	int cnt = 0;
	int prev = val[0];
	for (int i = 0; i <= val.size(); i++) {
		int cur = i < val.size() ? val[i] : -1;
		if (prev != cur) {
			append(out, cnt);
			out.push_back(prev);
			prev = cur;
			cnt = 1;
		}
		else {
			cnt++;
		}
	}
	return out;
}

void solve() {
	ll n, m; cin >> n >> m;
	
	if (n < vals.size()) {
		cout << (m < vals[n].size() ? vals[n][vals[n].size()-1-m] : 0) << endl;
	}
	else {
		n %= 2;
		n ++;
		n%=2;

		cout << (vals[vals.size()-1-n][vals[vals.size()-1-n].size()-1-m]) << endl;
	}
}

int main() {
	int t; cin >> t;
	vector<bool> init;
	vals.push_back({});
	init = {1};

	int cnt = 0;
	while (init.size() < mn) {
		cnt++;
		vals.push_back(init);
		init = iter(init);
	}
	vals.push_back(init);
	init = iter(init);
	vals.push_back(init);
	init = iter(init);
	
	while (t--) solve();
}

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

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 90ms
memory: 5032kb

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: 91ms
memory: 4916kb

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: 89ms
memory: 4928kb

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: 188ms
memory: 4940kb

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