結果
| 問題 | 
                            No.1113 二つの整数 / Two Integers
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2020-07-26 15:48:04 | 
| 言語 | C++14  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 2 ms / 1,000 ms | 
| コード長 | 918 bytes | 
| コンパイル時間 | 1,453 ms | 
| コンパイル使用メモリ | 167,632 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-06-28 16:32:42 | 
| 合計ジャッジ時間 | 2,094 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 2 | 
| other | AC * 15 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
// ------------------------------------------------------------
// けんちょんさんのブログからコピペ
// https://qiita.com/drken/items/0c88a37eec520f82b788
long long GCD(long long a, long long b) {
    if (b == 0) return a;
    else return GCD(b, a % b);
}
// ここまでコピペ
// ------------------------------------------------------------
int main() {
    // 入力
    long long a, b;
    cin >> a >> b;
    // a > b にしたい
    if(a < b) {
        long long tmp = a;
        a = b;
        b = tmp;
    }
    // 最大公約数を計算
    long long gcd = GCD(a, b);
    // gcdがある整数pの2乗で表せるならodd
    long long p = sqrt(gcd);
    for(long long i = p-100; i < p+100; ++i) {
        if(i*i == gcd) {
            cout << "Odd" << endl;
            return 0;
        }
    }
    cout << "Even" << endl;
    return 0;
}