結果
問題 | No.2417 Div Count |
ユーザー | tsunamayo123 |
提出日時 | 2023-08-12 14:12:03 |
言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 11 ms / 2,000 ms |
コード長 | 2,235 bytes |
コンパイル時間 | 4,690 ms |
コンパイル使用メモリ | 269,128 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-19 17:50:23 |
合計ジャッジ時間 | 6,082 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 41 |
ソースコード
#if !__INCLUDE_LEVEL__ #include __FILE__ /* divisor(n) 入力:整数 n 出力:nのすべての約数 計算量:O(√n) */ vector<long long> divisor(long long n) { vector<long long> ret; for (long long i = 1; i * i <= n; i++) { if (n % i == 0) { ret.push_back(i); if (i * i != n) ret.push_back(n / i); } } sort(ret.begin(), ret.end()); // 昇順に並べる return ret; } void solve(){ ll N,K; cin>>N>>K; vector n = divisor(N-K); debug(n); int cnt=0; rep(i,sz(n))if(n[i]>K)cnt++; cout<<cnt<<endl; } #else #include <bits/stdc++.h> #include <atcoder/all> using namespace std; using namespace atcoder; #pragma GCC target("avx2") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #define FOR(i,l,r) for(int i=(l);i<(r);++i) #define rep(i,n) FOR(i,0,n) using ll = long long; using ull = unsigned long long; using pii = pair<int, int>; using pll = pair<long long,long long>; using vi = vector<int>; using vs = vector<string>; using vll = vector<long long>; #define pf push_front #define pb push_back #define mp make_pair #define fi first #define se second #define sz(x) ((int)x.size()) #define pqueue priority_queue #define all(x) (x).begin(), (x).end() #define rall(x) (x).rbegin(), (x).rend() int dx[4] = {1, 0, -1, 0}; int dy[4] = {0, 1, 0, -1}; #define INF (1<<30)-1 #define INFLL (1LL<<60)-1 #define pcnt __builtin_popcount #define bit(n) (1LL<<(n)) #define UNIQUE(v) v.erase(unique(v.begin(),v.end()),v.end()); template<typename T> void out(T vec){for(int c:vec)cout<<c<<' ';} void yn(bool flag){if(flag)cout<<"Yes"<<'\n'; else cout<<"No"<<'\n';} template <typename T> bool chmax(T &a,const T& b){if(a<b){a=b;return true;}return false;} template <typename T> bool chmin(T &a,const T& b){if(a>b){a=b;return true;}return false;} void solve(); // const int mod = ; // using mint = modint998244353; // using mint = modint1000000007; #ifdef LOCAL # include <debug_print.hpp> # define debug(...) debug_print::multi_print(#__VA_ARGS__, __VA_ARGS__) #else # define debug(...) (static_cast<void>(0)) #endif int main(){ cin.tie(0); ios::sync_with_stdio(0); cout<<fixed<<setprecision(10); solve(); } #endif