結果

問題 No.136 Yet Another GCD Problem
コンテスト
ユーザー sansaqua
提出日時 2019-08-06 13:55:51
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 1,215 bytes
コンパイル時間 932 ms
コンパイル使用メモリ 87,108 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-07-18 13:55:17
合計ジャッジ時間 1,998 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 39
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <vector>
#include <utility>
#include <set>
#include <list>
#include <cassert>
#include <queue>
#include <cmath>
#include <algorithm>

using namespace std;
using ll = long long int;
#define REP(i, n) for(int i = 0; i < (int)(n); i++)
#define YES(n) std::cout << ((n) ? "YES" : "NO"  ) << "\n";
#define Yes(n) std::cout << ((n) ? "Yes" : "No" ) << "\n";

#define ALL_INCLUDED_ENVIRONMENT

template <class T, class Alloc, template <class, class> class C> std::ostream& operator<<(std::ostream& o, const C<T, Alloc>& v) {
  o << "{";
  bool init = 1;
  for (auto e : v) {
    if (init) { init = 0; }
    else { o << ", "; }
    o << e;
  }
  o << "}";
  return o;
}

template <class T> vector<T> enum_divisors(T x) {
  x = std::abs(x);
  long long sqrt = std::floor(std::sqrt(x));
  vector<T> res;
  for (T i = 1; i <= sqrt; i++) {
    if (x % i == 0) {
      res.push_back(i);
      if (i * i != x) {
        res.push_back(x/i);
      }
    }
  }
  return res;
}

int main() {
  // cin.tie(0);
  // ios::sync_with_stdio(false);
  ll n, k;
  cin >> n >> k;
  vector<ll> divs = enum_divisors(n);
  sort(divs.begin(), divs.end(), std::greater<ll>());
  cout << divs[1] << "\n";
  return 0;
}
0