結果
問題 | No.1218 Something Like a Theorem |
ユーザー | IKyopro |
提出日時 | 2020-09-04 21:25:29 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 6 ms / 2,000 ms |
コード長 | 971 bytes |
コンパイル時間 | 1,767 ms |
コンパイル使用メモリ | 191,644 KB |
最終ジャッジ日時 | 2025-01-14 04:57:48 |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 16 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; template <class T> using vec = vector<T>; template <class T> using vvec = vector<vec<T>>; template<class T> bool chmin(T& a,T b){if(a>b) {a = b; return true;} return false;} template<class T> bool chmax(T& a,T b){if(a<b) {a = b; return true;} return false;} #define debug(x) cerr << #x << " = " << (x) << endl; int main(){ cin.tie(0); ios::sync_with_stdio(false); ll N,Z; cin >> N >> Z; if(N==1){ cout << (Z!=1? "Yes\n":"No\n"); return 0; } ll z = 1; for(int i=0;i<N;i++) z *= Z; for(int x=1;x<=1000;x++) for(int y=1;y<=1000;y++){ ll a = 1; for(int i=0;i<N;i++){ a *= x; if(a>z) break; } ll b = 1; for(int i=0;i<N;i++){ b *= y; if(b>z) break; } if(a+b==z){ cout << "Yes\n"; return 0; } } cout << "No\n"; }