結果

問題 No.550 夏休みの思い出(1)
ユーザー hiyokko2
提出日時 2017-07-29 14:09:37
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
(最新)
AC  
(最初)
実行時間 -
コード長 1,006 bytes
コンパイル時間 2,018 ms
コンパイル使用メモリ 160,512 KB
実行使用メモリ 6,824 KB
最終ジャッジ日時 2024-10-11 05:39:20
合計ジャッジ時間 3,038 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 54 WA * 1
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:43:5: warning: ‘Z’ may be used uninitialized in this function [-Wmaybe-uninitialized]
   43 |     if (Y > Z) swap(Y, Z);
      |     ^~

ソースコード

diff #

#include <bits/stdc++.h>
#define FOR(i,bg,ed) for(ll i=(bg);i<(ed);i++)
#define REP(i,n) FOR(i,0,n)
#define MOD 1000000007
//#define int long long
using namespace std;
typedef long long ll;
typedef vector<vector<ll>> mat;
const int INF = 1e9;



signed main()
{
    ll A, B, C, X, Y, Z;
    cin >> A >> B >> C;

    for (X=-1000000; X<=1000000; X++) {
        if ((__int128_t)X*X*X + (__int128_t)A*X*X + (__int128_t)B*X + C == 0) {
            break;
        }
    }

    if (X == 0) {
        C = B;
        B = A;
    } else {
        B = A + X;
        C = -C / X;
    }

    double D = max(0.0, (double)B*B - 4*C);
    for (Y=(-B+sqrt(D))/2-2; Y<=(-B+sqrt(D))/2+2; Y++) {
        Z = -B - Y;
        if (abs(Y) >= 1000000000) continue;
        if (abs(Z) >= 1000000000) continue;
        if (Y * Z != C) continue;
        if (Y + Z != -B) continue;
        break;
    }

    if (X > Y) swap(X, Y);
    if (Y > Z) swap(Y, Z);
    if (X > Y) swap(X, Y);

    cout << X << " " << Y << " " << Z << endl;
}
0