結果

問題 No.2953 Maximum Right Triangle
ユーザー eve__fuyukieve__fuyuki
提出日時 2024-11-08 23:09:05
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
WA  
実行時間 -
コード長 1,070 bytes
コンパイル時間 2,261 ms
コンパイル使用メモリ 201,072 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-11-08 23:09:08
合計ジャッジ時間 2,470 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
5,248 KB
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;

void fast_io() {
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
}
void solve() {
	long long d, x, y;
	cin >> d >> x >> y;
	long long dx = x, dy = y;
	long long g = gcd(x, y);
	x /= g;
	y /= g;
	long long ok_h = 0, ng_h = d + 1;
	auto is_ok = [&](long long h) -> bool {
		long long xx = x + h * dy;
		long long yy = y - h * dx;
		return xx >= 0 && yy >= 0 && xx + yy <= d;
	};
	while (ok_h + 1 < ng_h) {
		long long mid = (ok_h + ng_h) / 2;
		if (is_ok(mid)) {
			ok_h = mid;
		} else {
			ng_h = mid;
		}
	}
	long long ng_l = -d - 1, ok_l = 0;
	while (ng_l + 1 < ok_l) {
		long long mid = (ng_l + ok_l) / 2;
		if (is_ok(mid)) {
			ok_l = mid;
		} else {
			ng_l = mid;
		}
	}
	long long ans = 0;
	{
		long long xx = x + ok_h * dy;
		long long yy = y - ok_h * dx;
		ans = max(ans, abs(xx * y - yy * x));
	}
	{
		long long xx = x + ok_l * dy;
		long long yy = y - ok_l * dx;
		ans = max(ans, abs(xx * y - yy * x));
	}
	cout << ans << "\n";
}
int main() {
	fast_io();
	int t;
	cin >> t;
	for (; t--;) {
		solve();
	}
}
0