結果
問題 | No.800 四平方定理 |
ユーザー |
![]() |
提出日時 | 2019-03-17 22:01:08 |
言語 | C++11 (gcc 13.3.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,135 bytes |
コンパイル時間 | 1,469 ms |
コンパイル使用メモリ | 159,192 KB |
実行使用メモリ | 10,880 KB |
最終ジャッジ日時 | 2024-07-07 22:48:58 |
合計ジャッジ時間 | 29,230 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 TLE * 1 |
other | AC * 15 TLE * 6 -- * 9 |
ソースコード
#include <bits/stdc++.h> using namespace std; int main() { // 1. 入力情報取得. int N, D; cin >> N >> D; // 2. 解を確認. int ans = 0; for(int x = 1; x < N + 1; x++){ for(int y = x; y < N + 1; y++){ for(int z = y; z < N + 1; z++){ int c = x * x + y * y + z * z - D; int w = sqrt(c + 0.0); if(c == w * w && w <= N && w >= 1){ if(x != y && y != z && z != x) ans += 6; if(x != y && y != z && z == x) ans += 3; if(x != y && y == z && z != x) ans += 3; if(x == y && y != z && z != x) ans += 3; if(x != y && y == z && z == x) ans += 2; if(x == y && y != z && z == x) ans += 2; if(x == y && y == z && z != x) ans += 2; if(x == y && y == z && z == x) ans += 1; // cout << "x=" << x << " y=" << y << " z=" << z << " w=" << w << endl; } } } } // 3. 後処理. cout << ans << endl; return 0; }