QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#680918#5115. Clone Ranran2317663977AC ✓22ms3660kbC++23572b2024-10-26 23:32:152024-10-26 23:32:26

Judging History

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

  • [2024-10-26 23:32:26]
  • 评测
  • 测评结果:AC
  • 用时:22ms
  • 内存:3660kb
  • [2024-10-26 23:32:15]
  • 提交

answer

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>
#include <set>
#include <map>
#include <queue>
#include <cmath>
#include <cstring>

using ll = long long;

ll a, b, c;

void solve()
{
	cin >> a >> b >> c;
	ll now = 0;
	ll ans = c * b;
	ll ren = 1;
	while (ren < c)
	{
		now += a;
		ren *= 2;
		ans = min(ans, (ll)ceil((double)c / ren) * b + now);
	}
	cout << ans << '\n';
}

int main()
{
	ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
	int T = 1;
	cin >> T;
	while (T--)
	{
		solve();
	}
	return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 3660kb

input:

5
1 1 1
2 3 3
9 9 9
3 26 47
1064 822 1048576

output:

1
7
45
44
21860

result:

ok 5 number(s): "1 7 45 44 21860"

Test #2:

score: 0
Accepted
time: 22ms
memory: 3608kb

input:

99500
1000000000 1000000000 1000000000
1000000000 1000000000 999999999
1000000000 1000000000 999999998
1000000000 1000000000 999999997
1000000000 1000000000 999999996
1000000000 1000000000 999999995
1000000000 1000000000 999999994
1000000000 1000000000 999999993
1000000000 1000000000 999999992
10000...

output:

31000000000
31000000000
31000000000
31000000000
31000000000
31000000000
31000000000
31000000000
31000000000
31000000000
30999999998
30999999998
30999999998
30999999998
30999999998
30999999998
30999999998
30999999998
30999999998
30999999998
30999999996
30999999996
30999999996
30999999996
30999999996
...

result:

ok 99500 numbers