結果
問題 | No.136 Yet Another GCD Problem |
ユーザー | rana |
提出日時 | 2021-09-13 09:31:42 |
言語 | C++17(clang) (17.0.6 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,034 bytes |
コンパイル時間 | 1,221 ms |
コンパイル使用メモリ | 141,284 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-25 08:18:05 |
合計ジャッジ時間 | 2,398 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 39 |
ソースコード
#include <algorithm> #include <deque> #include <iomanip> #include <iostream> #include <map> #include <math.h> #include <numeric> #include <ostream> #include <queue> #include <set> #include <stack> #include <vector> using namespace std; #define ll long long #define ld long double #define all(v) begin(v), end(v) #define rep(i, n) for (ll i = 0; i < n; ++i) #define rep2(i, n, m) for (ll i = n; i <= m; ++i) #define rep3(i, n, m) for (ll i = n; i >= m; --i) template<class S, class T> bool chmax(S& a, T& b) { if (a < b) { a = b; return true; } return false; } template<class S, class T> bool chmin(S& a, T& b) { if (a > b) { a = b; return true; } return false; } int main(void) { ll n, k; cin >> n >> k; vector<ll> gs; gs.push_back(1); rep2(i, 2, sqrt(n)) { if (n % i == 0) { ll a = i, b = n / i; if (a * 2 <= n) gs.push_back(a); if (b * 2 <= n) gs.push_back(b); } } cout << *max_element(all(gs)) << endl; return (0); }