QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#586286#4431. Interesting NumbersWorld_CreaterAC ✓18ms7152kbC++171.1kb2024-09-24 10:20:502024-09-24 10:20:50

Judging History

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

  • [2024-09-24 10:20:50]
  • 评测
  • 测评结果:AC
  • 用时:18ms
  • 内存:7152kb
  • [2024-09-24 10:20:50]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
int t,n,m,q;
struct trie{
	int tree[600005][2],sz[600005];
	int cnt;
	void clear()
	{
		for(int i=1;i<=cnt;i++) tree[i][0]=tree[i][1]=sz[i]=0;
		cnt=1;
	}
	void insert(int x)
	{
		int p=1;
		sz[p]++;
		for(int i=19;i>=0;i--)
		{
			int c=x>>i&1;
			if(!tree[p][c]) tree[p][c]=++cnt;
			p=tree[p][c];
			sz[p]++;
		}
	}
	int solve(int p1,int p2,int d=19)
	{
		if(!p1||!p2||d==-1) return sz[p1]+sz[p2];
		int s=max(sz[p1],sz[p2]);
		if(m>>d&1)
		{
			if(p1==p2) return solve(tree[p1][0],tree[p1][1],d-1);
			else return max(s,solve(tree[p1][0],tree[p2][1],d-1)+solve(tree[p1][1],tree[p2][0],d-1));
		}
		else
		{
			if(p1==p2) return max(solve(tree[p1][0],tree[p1][0],d-1),solve(tree[p1][1],tree[p1][1],d-1));
			else return max({s,solve(tree[p1][0],tree[p2][0],d-1),solve(tree[p1][1],tree[p2][1],d-1)});
		}
	}
}T;
int main()
{
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>t;
	while(t--)
	{
		cin>>n>>m;
		T.clear();
		for(int i=1;i<=n;i++)
		{
			int x;
			cin>>x;
			T.insert(x);
		}
		cout<<T.solve(1,1)<<"\n";
	}
}

详细

Test #1:

score: 100
Accepted
time: 18ms
memory: 7152kb

input:

6
30000 887788
295744 887428 33604 327716 100488 363104 299908 329892 100808 34952 557256 100996 821280 334560 68216 854944 297148 960 362788 68096 622628 625250 788548 360737 328264 524932 592672 361026 8780 164004 327808 262656 297024 624772 98376 395652 263052 524404 224 623244 344616 622944 2976...

output:

19915
18057
25682
14945
15025
3880

result:

ok 6 lines

Test #2:

score: 0
Accepted
time: 14ms
memory: 6732kb

input:

203
200 83
451 494 342 47 98 470 991 145 83 626 484 517 377 169 388 754 386 651 620 637 565 827 559 214 591 315 113 754 405 307 72 699 674 399 369 19 1009 42 932 349 737 286 834 391 982 647 927 515 840 110 239 454 350 775 457 728 290 78 610 890 51 127 410 316 957 571 180 803 383 308 335 738 281 921 ...

output:

24
21
12
54
105
66
33
19
112
36
12
13
12
56
63
101
20
19
100
19
136
30
24
11
62
59
23
16
18
36
59
17
17
18
33
120
34
15
18
17
32
14
56
14
32
103
55
123
57
11
11
37
30
19
20
60
30
110
64
14
11
36
12
109
20
55
106
24
44
56
55
33
19
36
120
102
34
20
64
112
19
11
21
12
134
39
10
11
65
34
100
110
12
52
1...

result:

ok 203 lines

Test #3:

score: 0
Accepted
time: 0ms
memory: 5696kb

input:

1000
20 20
451 494 342 47 98 470 991 145 83 626 484 517 377 169 388 754 386 651 620 637
20 99
203 85 581 483 268 875 150 167 84 678 371 799 409 531 552 987 604 6 791 609
20 169
391 982 647 927 515 840 110 239 454 350 775 457 728 290 78 610 890 51 127 410
20 83
798 759 347 702 842 251 936 193 359 784...

output:

2
3
4
4
5
3
2
5
2
5
1
2
10
19
3
4
2
4
3
1
7
3
2
4
2
14
1
3
6
2
6
2
1
6
9
2
7
2
5
6
2
3
3
6
11
5
1
8
7
2
5
2
10
4
1
13
5
12
3
4
17
12
5
3
2
3
6
5
4
3
4
2
3
4
7
3
3
2
11
2
6
1
4
5
8
2
6
2
3
3
9
18
6
11
2
7
9
7
2
3
3
5
2
3
10
5
14
4
2
1
2
14
9
2
7
2
3
2
11
4
7
6
2
2
2
7
8
2
7
3
2
11
3
2
3
2
1
2
12
4
2
...

result:

ok 1000 lines

Extra Test:

score: 0
Extra Test Passed