QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#101952#6. 玛里苟斯Larunatrecy100 ✓124ms4352kbC++141.4kb2023-05-01 21:50:212023-05-01 21:50:23

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-05-01 21:50:23]
  • 评测
  • 测评结果:100
  • 用时:124ms
  • 内存:4352kb
  • [2023-05-01 21:50:21]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
typedef __int128 Big;
typedef unsigned  long long ULL;
int n,K;
const int N = 1e5+7;
ULL a[N];
void write(Big x)
{
	if(!x)return;
	write(x/10);
	putchar(x%10+'0');
}
ULL d[25];
void Ins(ULL v)
{
	for(int i=23;i>=0;i--)
	if((v>>i)&1)
	{
		if(d[i])v^=d[i];
		else
		{
			d[i]=v;
			return;
		}
	}
}
int m;
ULL D[120];
int main()
{
	scanf("%d %d",&n,&K);
	Big W=0;
	for(int i=1;i<=n;i++)scanf("%llu",&a[i]),W|=a[i];
	if(K==1)
	{
		Big sum=0,w=1;
		for(ULL i=0;i<=64;i++)
		{
			ULL c=((W>>i)&1ll);
			if(c)sum=sum+w;
			w=w+w;
		}
		write(sum/2);
		if(sum%2==1)printf(".5");
		return 0; 
	}
	if(K==2)
	{
		Big sum=0;
		for(int i=0;i<64;i++)
		for(int j=0;j<64;j++)
		if(((W>>i)&1ull)&&((W>>j)&1ull))
		{
			bool flag=0;
			for(int k=1;k<=n;k++)
			if(((a[k]>>i)&1ull)!=((a[k]>>j)&1ull))flag=1;
			Big w=1;
			for(int k=1;k<=i+j;k++)w=w+w;
			if(!flag)sum+=w*2;
			else sum+=w;
		}
		sum/=2;
		write(sum/2);
		if(sum%2==1)cout<<".5";
		return 0;
	}
	for(int i=1;i<=n;i++)Ins(a[i]);
	for(int i=0;i<=23;i++)
	if(d[i])D[++m]=d[i];
	Big ans=0;
	for(int S=0;S<(1<<m);S++)
	{
		Big v=0,w=1;
		for(int i=1;i<=m;i++)
		if((S>>(i-1))&1)v^=D[i];
		for(int j=1;j<=K;j++)w=w*v;
		ans+=w;
	}
	ans>>=(m-1);
	write(ans/2);
	if(ans%2==1)cout<<".5";
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 5
Accepted
time: 15ms
memory: 4200kb

input:

93348 1
1
2
4
9
25
52
81
133
508
652
1903
3296
5019
14045
18897
39827
81761
164654
433137
873979
1760925
2191486
7119527
14976120
19550122
56863700
91579561
181786097
320782698
677088935
1847381903
2214472334
6489287469
15349585339
22417199361
64252243732
127008028892
253725946829
497102455446
10445...

output:

9223372036854775807.5

result:

ok single line: '9223372036854775807.5'

Test #2:

score: 5
Accepted
time: 19ms
memory: 4228kb

input:

96800 1
14051766699896359
7215410969988351
16776696067864826
7632921873870586
12557076885174912
9161735894052404
15980916402619673
17968380965733216
11261263426099215
1424382964472915
5728555547066265
14908601420989880
14030145822431125
16379643591472362
11558257546383490
5684152043872785
5196436283...

output:

9007199254740991.5

result:

ok single line: '9007199254740991.5'

Test #3:

score: 5
Accepted
time: 6ms
memory: 4300kb

input:

95221 1
541
541
61
544
376
61
61
325
1340
1625
856
869
376
325
1636
544
1145
1281
1145
1340
1636
1820
1820
1625
1820
0
61
1825
376
1145
325
1145
1340
325
376
1281
0
1820
325
1281
1820
541
325
869
1825
1820
1281
376
376
1625
856
856
1281
1825
1145
1340
376
1281
1281
869
541
856
1825
1281
1281
1092
54...

output:

958.5

result:

ok single line: '958.5'

Test #4:

score: 5
Accepted
time: 12ms
memory: 4244kb

input:

98533 1
3708816
4210066
1308040
5434845
7910693
1308040
340294
7907595
5097203
4782005
3775884
4045297
848253
7625599
340559
5751740
3039403
276563
2843160
7688810
1785775
3103042
5903375
3034992
583164
3976394
8231748
7898832
5109263
5912797
5494589
652238
7233072
4530959
340559
2529657
3502072
310...

output:

4194303.5

result:

ok single line: '4194303.5'

Test #5:

score: 5
Accepted
time: 124ms
memory: 4252kb

input:

99218 2
1
2
7
11
31
62
89
133
440
542
1168
3630
5715
9335
22179
46247
89580
194345
438141
1032713
1538482
3074213
5533309
10366154
24031543
55097817
83511187
173451015
536744384
812063048
1419004740
4033891637
4196467447
1019527648
3299473730
1996992967
3674463225
651220214
34624954
137660395
310456...

output:

6148914689089033557.5

result:

ok single line: '6148914689089033557.5'

Test #6:

score: 5
Accepted
time: 112ms
memory: 4184kb

input:

96578 2
2142966981
2057970579
650230902
614791007
2009993626
1503336264
1843254468
344954375
1034874026
1836303812
1330950372
1062930152
1808725968
1345032296
742153662
144209584
778791656
958176703
310646776
648544269
1589164918
1353992516
795183608
1551098207
1044570885
1275989152
746346323
161141...

output:

1537228671735387477.5

result:

ok single line: '1537228671735387477.5'

Test #7:

score: 5
Accepted
time: 112ms
memory: 4220kb

input:

94187 2
1957907055
3931003789
2005347316
2544301452
1497132383
3152717565
1181858491
3483019990
4170106259
4055750004
4003470954
1974284488
1144991575
2668423078
3471595561
1583551589
1406011571
708388628
2126694511
747605046
1718302214
2193548222
2669308194
2258324117
1472721468
834409926
398749751...

output:

6148914689089033557.5

result:

ok single line: '6148914689089033557.5'

Test #8:

score: 5
Accepted
time: 85ms
memory: 4336kb

input:

90891 2
118554447
298165489
188351639
377308761
367689478
178508150
442268442
264391947
57586167
382022377
172829829
36075824
406112676
126474848
330208701
92046913
326570291
291751316
14008758
231762663
354234446
533562288
449834557
532237997
2899563
171139218
93795221
116023039
132785778
243837301...

output:

96076791782135125.5

result:

ok single line: '96076791782135125.5'

Test #9:

score: 5
Accepted
time: 112ms
memory: 4352kb

input:

90619 3
1
3
7
10
28
36
124
186
424
906
1647
2462
6234
9933
27809
53072
68578
142700
362823
654554
1984087
157994
693201
322850
116492
610036
204838
1345906
696265
342996
1078802
1317315
835765
1523925
1145451
520990
1733279
1317634
1398717
983003
1114840
302148
1618973
1693935
686085
434399
247741
1...

output:

2305840810190962688

result:

ok single line: '2305840810190962688'

Test #10:

score: 5
Accepted
time: 17ms
memory: 4252kb

input:

99692 3
54966
49725
36175
19283
46374
36992
41651
19295
61003
31483
17700
62315
6815
36564
47174
40308
1218
27082
24730
17759
65206
17083
12912
49829
50463
58622
9856
251
16677
59372
17149
47128
28281
63288
44046
32455
2759
25380
39233
31057
36170
6518
15121
44269
16701
26455
53637
20422
61692
31173...

output:

70366596710400

result:

ok single line: '70366596710400'

Test #11:

score: 5
Accepted
time: 12ms
memory: 4272kb

input:

98665 3
210
27
27
110
0
188
0
129
188
201
244
38
188
239
210
83
129
27
188
188
244
38
167
27
188
110
154
0
129
210
0
244
27
154
244
154
83
244
72
110
239
244
117
167
110
129
83
201
72
244
129
110
0
61
38
239
72
110
27
188
38
72
129
201
83
210
201
201
117
154
201
83
239
38
0
83
129
129
72
239
188
72
...

output:

4177536

result:

ok single line: '4177536'

Test #12:

score: 5
Accepted
time: 12ms
memory: 4208kb

input:

93587 3
31263
13029
42528
12794
16841
26681
48758
3271
6993
4778
22541
23342
39968
28137
51098
8355
37051
50543
47728
30027
58097
46182
19500
29713
30216
4489
23204
45019
1170
54271
48866
41614
32405
21049
11722
5664
49886
6703
48026
5325
63960
11809
18302
60322
573
3774
60753
26681
57742
64934
4422...

output:

70366596710400

result:

ok single line: '70366596710400'

Test #13:

score: 5
Accepted
time: 21ms
memory: 4200kb

input:

99711 4
1
3
4
9
21
60
112
233
371
857
2008
3740
4360
8778
24463
63257
51889
62102
13543
14856
5708
21083
36755
51081
21762
38599
9190
63703
29413
41985
40595
4474
14114
5556
40949
56375
41901
16928
43079
31958
38357
52247
24836
59723
60762
62591
45398
46165
33783
11491
15363
35607
16225
58700
6431
5...

output:

3689208078685210760.5

result:

ok single line: '3689208078685210760.5'

Test #14:

score: 5
Accepted
time: 7ms
memory: 4340kb

input:

91509 4
437
94
988
94
898
94
567
994
172
172
96
94
599
395
956
327
956
677
395
295
709
94
599
898
763
295
667
880
395
281
956
709
846
898
763
677
521
295
62
204
395
994
599
172
172
784
172
880
469
295
567
599
295
395
62
0
295
96
994
814
880
898
617
677
880
327
880
677
377
677
281
846
146
521
763
0
3...

output:

219160771256.5

result:

ok single line: '219160771256.5'

Test #15:

score: 5
Accepted
time: 12ms
memory: 4156kb

input:

92430 4
18697
13758
12489
31927
1399
1399
15077
1399
15077
12489
18002
13758
2604
18002
19582
16274
17189
3931
16274
0
16274
16274
16274
31927
31927
19582
30363
15077
16274
2604
0
19582
0
12489
3931
15077
29676
18697
16274
31168
2604
12489
0
30363
13758
19582
19582
18002
15077
29676
0
29676
13758
29...

output:

265753624987159112.5

result:

ok single line: '265753624987159112.5'

Test #16:

score: 5
Accepted
time: 11ms
memory: 4152kb

input:

91817 4
6247
3781
6698
8841
466
8498
13838
3208
11300
4406
6773
1497
13734
3361
6581
15175
7079
3967
4766
5446
13228
589
12219
8557
5834
5461
14260
14484
8435
12850
13211
549
13698
13926
76
10251
13247
15115
3809
8983
15528
7172
11794
11156
12717
8498
10324
7614
14315
11264
1442
4457
1955
6247
2268
...

output:

14409319974865032.5

result:

ok single line: '14409319974865032.5'

Test #17:

score: 5
Accepted
time: 16ms
memory: 4260kb

input:

99478 5
1
3
5
9
26
35
86
164
420
1019
1088
3607
6424
4029
1253
2314
3020
7503
3077
3742
7766
846
929
7718
2395
5341
780
4323
7760
1906
5293
6795
711
3814
3962
1085
4728
5645
4355
1429
3901
6005
8091
6820
6829
4903
420
6523
722
6630
2979
7779
7
5045
8032
1083
1320
2955
1669
6485
34
7698
6811
434
5656...

output:

6146663120487753728

result:

ok single line: '6146663120487753728'

Test #18:

score: 5
Accepted
time: 12ms
memory: 4252kb

input:

99213 5
485
426
161
79
346
436
191
346
277
426
238
277
346
79
485
507
79
277
191
436
324
436
436
485
191
238
161
324
30
240
507
277
436
79
191
426
240
30
324
81
81
79
0
81
240
324
436
267
485
485
507
81
240
161
485
81
426
277
240
240
79
507
436
30
507
30
161
0
324
426
267
238
485
240
426
240
0
0
238...

output:

6472883376848

result:

ok single line: '6472883376848'

Test #19:

score: 5
Accepted
time: 11ms
memory: 4256kb

input:

99889 5
19
28
34
19
34
45
28
34
49
34
19
15
49
0
45
49
45
19
62
28
62
19
34
28
62
45
0
28
0
19
45
28
28
45
15
19
19
15
34
0
28
15
19
45
49
15
15
45
34
49
0
34
34
45
15
49
0
28
28
0
34
28
15
62
45
19
45
34
62
28
49
34
15
28
15
49
49
0
28
45
34
15
19
49
49
19
15
15
28
19
28
0
62
45
15
49
49
0
28
19
19...

output:

181127184

result:

ok single line: '181127184'

Test #20:

score: 5
Accepted
time: 14ms
memory: 4252kb

input:

99139 5
1894
178
1837
325
240
1987
155
2037
572
1211
631
146
1986
1557
576
1140
664
1632
502
489
1565
664
1230
630
2004
141
141
1222
1141
1836
1535
963
294
75
1265
1140
9
66
332
896
503
133
1503
794
427
471
1953
881
1982
2027
1961
1578
248
124
1013
1437
573
1597
1502
1579
1526
488
2005
1130
1091
173...

output:

5996021955078656

result:

ok single line: '5996021955078656'