TakahiroNakamori

TakahiroNakamori

ナカモリタカヒロ

 
 

Partition

問題

D – Partition
プログラミング初級者から上級者まで楽しめる、競技プログラミングコンテストサイト「AtCoder」。オンラインで毎週開催プログラミングコンテストを開催しています。競技…

記録

解法

コード例

#include <bits/stdc++.h>
using namespace std;
#include <atcoder/all>
using namespace atcoder;
using ll = long long;
using P = pair<int, int>;
#define rep(i, n) for(int i = 0; i < (n); ++i)
// using mint = modint998244353;
// using mint = modint1000000007;
// const int mod = 1000000007;
// const ll INF = 1LL << 60;
// const int INF = 1001001001;

vector<int> divisor(int N) {
  vector<int> res;
  for(int i = 1; i * i <= N; i++) {
    if(N % i == 0) {
      res.push_back(i);
      if(i != N / i) {
        res.push_back(N / i);
      }
    }
  }
  return res;
}

int main() {
  int N, M;
  cin >> N >> M;

  vector<int> d = divisor(M);
  sort(d.rbegin(), d.rend());
  int ans = 0;
  int n = d.size();
  rep(i, n) {
    int v = d[i];
    if(N <= M / v) {
      ans = max(ans, v);
    }
  }

  cout << ans << endl;
  return 0;
}