QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#808263#9156. 百万富翁Nelofus85 2829ms106784kbC++201.9kb2024-12-10 19:07:292024-12-10 19:07:36

Judging History

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

  • [2024-12-10 19:07:36]
  • 评测
  • 测评结果:85
  • 用时:2829ms
  • 内存:106784kb
  • [2024-12-10 19:07:29]
  • 提交

answer

// Code by Heratino & Nelofus
#include <bits/stdc++.h>
#include "richest.h"
using i64 = long long;

std::vector<int> ask(std::vector<int> a, std::vector<int> b);

std::vector<int> reduceAtoB(int a, int b, std::vector<int> vec) {
	assert(a == vec.size());
	std::vector<std::vector<int>> g(b);
	std::vector<int> ans(b);
	int l = 0;
	for (int i = 0; i < b; i++) {
		int r;
		if (i < a % b)
			r = l + a / b + 1;
		else
			r = l + a / b;
		for (int j = l; j < r; j++)
			g[i].push_back(vec[j]);
		l = r;
	}
	assert(l == a);

	// Part 2
	std::vector<int> qa, qb;
	std::vector<int> ap, bp;
	std::vector<int> gl, gr;
	auto SetToOne = [&](std::vector<int> s) {
		int n = s.size();
		gl.push_back(qa.size());
		for (int i = 0; i < n; i++)
			for (int j = i + 1; j < n; j++)
				qa.push_back(s[i]), qb.push_back(s[j]), ap.push_back(i), bp.push_back(j);
		gr.push_back(qa.size());
	};

	for (int i = 0; i < b; i++)
		SetToOne(g[i]);

	std::vector<int> qc = ask(qa, qb);

	// Part 3
	auto Recover = [&](const int &x) {
		int n = g[x].size();
		std::vector<int> cnt(n, 0);
		for (int i = gl[x]; i < gr[x]; i++) {
			if (qc[i] == qa[i])
				cnt[ap[i]]++;
			if (qc[i] == qb[i])
				cnt[bp[i]]++;
		}
		for (int i = 0; i < n; i++)
			if (cnt[i] == n - 1)
				return g[x][i];
		assert(0);
		return -1;
	};

	for (int i = 0; i < b; i++)
		ans[i] = Recover(i);
	return ans;
}
int richest(int N, int T, int S) {
	std::vector<int> ans(N);
	for (int i = 0; i < N; i++)	ans[i] = i;
	// 1000000 500000 250000 125000 62500 20832 3472 183 1
	ans = reduceAtoB(1000000, 500000, ans);
	ans = reduceAtoB(500000, 250000, ans);
	ans = reduceAtoB(250000, 125000, ans);
	ans = reduceAtoB(125000, 62500, ans);
	ans = reduceAtoB(62500, 20832, ans);
	ans = reduceAtoB(20832, 3472, ans);
	ans = reduceAtoB(3472, 183, ans);
	ans = reduceAtoB(183, 1, ans);
	return ans[0];
}

详细


Pretests

Pretest #1:

score: 0
Runtime Error

input:

1000 1 499500 957319859

output:

Unauthorized output

result:


Pretest #2:

score: 85
Accepted
time: 2829ms
memory: 106784kb

input:

1000000 20 2000000 29091473

output:

Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944
7610580723948932399
1.000000
1331569654267968081

result:

points 1.0 Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944


Final Tests

Test #1:

score: 0
Runtime Error

input:

1000 1 499500 957319857

output:

Unauthorized output

result:


Test #2:

score: 85
Accepted
time: 2824ms
memory: 106100kb

input:

1000000 20 2000000 29091471

output:

Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944
7610580723948932399
1.000000
1331569654267968081

result:

points 1.0 Correct Case 2, 85 / 85, maxt = 8, maxs = 1099944