QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#507100#9156. 百万富翁251Sec74.99997 2144ms102208kbC++141.4kb2024-08-06 10:51:432024-08-06 10:51:45

Judging History

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

  • [2024-08-06 10:51:45]
  • 评测
  • 测评结果:74.99997
  • 用时:2144ms
  • 内存:102208kb
  • [2024-08-06 10:51:43]
  • 提交

answer

#include <bits/stdc++.h>
#include "richest.h"
using namespace std;
int K[] = { 0, 500000, 250000, 125000, 62500, 20833, 3472, 183, 1 };
vector<int> Div(vector<int> a, int k) {
	int n = a.size(), p = 0, s = n / k;
	vector<int> x, y;
	for (int i = 0; i < n % k; i++) {
		for (int j = p; j < p + s + 1; j++) {
			for (int k = j + 1; k < p + s + 1; k++) {
				x.push_back(a[j]), y.push_back(a[k]);
			}
		}
		p += s + 1;
	}
	for (int i = 0; i < k - n % k; i++) {
		for (int j = p; j < p + s; j++) {
			for (int k = j + 1; k < p + s; k++) {
				x.push_back(a[j]), y.push_back(a[k]);
			}
		}
		p += s;
	}
	assert(p == n);
	p = 0;
	vector<int> c = ask(x, y), res;
	int cp = 0;
	for (int i = 0; i < n % k; i++) {
		int u = a[p];
		for (int j = p; j < p + s + 1; j++) {
			for (int k = j + 1; k < p + s + 1; k++) {
				int v = c[cp++];
				if (a[j] == u && a[k] == v) u = v;
			}
		}
		p += s + 1;
		res.push_back(u);
	}
	for (int i = 0; i < k - n % k; i++) {
		int u = a[p];
		for (int j = p; j < p + s; j++) {
			for (int k = j + 1; k < p + s; k++) {
				int v = c[cp++];
				if (a[j] == u && a[k] == v) u = v;
			}
		}
		p += s;
		res.push_back(u);
	}
	return res;
}
int richest(int N, int T, int S) {
	vector<int> a;
	for (int i = 0; i < N; i++) a.push_back(i);
	if (N == 1000) a = Div(a, 1);
	else {
		ask({ 1 }, { 2 });
		for (int i = 1; i <= 8; i++) a = Div(a, K[i]);
	}
    return a[0];
}

详细


Pretests

Pretest #1:

score: 15
Accepted
time: 602ms
memory: 21884kb

input:

1000 1 499500 957319859

output:

Correct
7127326332295218295
1.000000
1331569654267968081

result:

points 1.0 Correct

Pretest #2:

score: 60
Acceptable Answer
time: 2144ms
memory: 102208kb

input:

1000000 20 2000000 29091473

output:

Partially correct Case 2, 60 / 85, maxt = 9, maxs = 1099945
10628867421029533817
0.705882
2529992535630599163

result:

points 0.705882 Partially correct Case 2, 60 / 85, maxt = 9, maxs = 1099945


Final Tests

Test #1:

score: 15
Accepted
time: 620ms
memory: 23372kb

input:

1000 1 499500 957319857

output:

Correct
7127326332295218295
1.000000
1331569654267968081

result:

points 1.0 Correct

Test #2:

score: 60
Acceptable Answer
time: 2046ms
memory: 86576kb

input:

1000000 20 2000000 29091471

output:

Partially correct Case 2, 60 / 85, maxt = 9, maxs = 1099945
10628867421029533817
0.705882
2529992535630599163

result:

points 0.705882 Partially correct Case 2, 60 / 85, maxt = 9, maxs = 1099945