QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#490195#9156. 百万富翁strcmp#68.99999 2446ms88552kbC++141.2kb2024-07-25 12:40:102024-07-25 12:40:10

Judging History

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

  • [2024-07-25 12:40:10]
  • 评测
  • 测评结果:68.99999
  • 用时:2446ms
  • 内存:88552kb
  • [2024-07-25 12:40:10]
  • 提交

answer

#include <bits/stdc++.h>
//#include <windows.h>
using namespace std;
#include "richest.h"
#define rep(i, a, b) for(int i = a; i <= b; i++)
using vec = vector<int>;
using ll = long long int;
constexpr int maxn = 2e6 + 10;
#define ps push_back
int p[35] = { 500000, 250000, 125000, 62500, 31250, 15625, 5209, 882, 47, 1 }, cnt[maxn];
int richest(int n, int t, int s) {
	if (n <= 1000) {
		vec x, y, z;
		for (int i = 0; i < n - 1; i++) {
			for (int j = i + 1; j < n; j++) x.ps(i), y.ps(j);
		}
		z = ask(x, y); int ans = 0;
		for (int i = 0; i < z.size(); i++) {
			++cnt[z[i]];
			if (cnt[z[i]] == n - 1) ans = z[i];
		}
		for (int i = 0; i < z.size(); i++) --cnt[z[i]];
		return ans;
	}
	vec a; 
	for (int i = 0; i < n; i++) a.push_back(i);
	for (int i = 0; i < min(10, t); i++) {
		vec x, y;
		for (int j = 0; j < a.size(); j++) {
			for (int k = j % p[i]; k < j; k += p[i]) if (j != k) x.ps(a[j]), y.ps(a[k]);
		}
		vec z = ask(x, y), na;
		for (int j = 0; j < z.size(); j++) z[j] == x[j] ? ++cnt[y[j]] : ++cnt[x[j]];
		for (int j = 0; j < a.size(); j++) if (!cnt[a[j]]) na.ps(a[j]);
		for (int j = 0; j < z.size(); j++) z[j] == x[j] ? --cnt[y[j]] : --cnt[x[j]];
		a = na; 
	}
	return a[0];
}

Details

Tip: Click on the bar to expand more detailed information

Pretests

Pretest #1:

score: 15
Accepted
time: 639ms
memory: 27336kb

input:

1000 1 499500 957319859

output:

Correct
7127326332295218295
1.000000
1331569654267968081

result:

points 1.0 Correct

Pretest #2:

score: 54
Acceptable Answer
time: 2446ms
memory: 88236kb

input:

1000000 20 2000000 29091473

output:

Partially correct Case 2, 54 / 85, maxt = 10, maxs = 1021733
7243528335533031159
0.635294
4439523384460221017

result:

points 0.635294 Partially correct Case 2, 54 / 85, maxt = 10, maxs = 1021733


Final Tests

Test #1:

score: 15
Accepted
time: 630ms
memory: 27188kb

input:

1000 1 499500 957319857

output:

Correct
7127326332295218295
1.000000
1331569654267968081

result:

points 1.0 Correct

Test #2:

score: 54
Acceptable Answer
time: 2421ms
memory: 88552kb

input:

1000000 20 2000000 29091471

output:

Partially correct Case 2, 54 / 85, maxt = 10, maxs = 1021733
7243528335533031159
0.635294
4439523384460221017

result:

points 0.635294 Partially correct Case 2, 54 / 85, maxt = 10, maxs = 1021733