結果
問題 | No.8054 ほぼ直角二等辺三角形 |
ユーザー |
![]() |
提出日時 | 2019-04-01 23:03:20 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 7 ms / 2,000 ms |
コード長 | 929 bytes |
コンパイル時間 | 2,214 ms |
コンパイル使用メモリ | 198,712 KB |
最終ジャッジ日時 | 2025-01-07 01:10:42 |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 18 |
ソースコード
#include <bits/stdc++.h> using namespace std; long long a(int n) { if (n == 0) return 0; if (n == 1) return 3; if (n == 2) return 20; return 7 * a(n - 1) - 7 * a(n - 2) + a(n - 3); } using Long = __int128_t; long long sq(Long a) { Long l = 0; Long r = sqrt((double) a) + 100000; while (l < r - 1) { Long m = (l + r) / 2; if (m * m > a) { r = m; } else { l = m; } } return l; } int main() { vector<long long> ans = {3}; int len = 1; for (int i = 2; i <= 23; i++) { long long k = a(i); if (to_string(k).size() != len) { len = to_string(k).size(); ans.push_back(k); } } int n; cin >> n; cout << ans[n - 1] << ' ' << ans[n - 1] + 1 << ' '; Long s = Long(ans[n - 1]) * ans[n - 1]; s += Long(ans[n - 1] + 1) * (ans[n - 1] + 1); cout << sq(s) << endl; }