結果
問題 | No.955 ax^2+bx+c=0 |
ユーザー |
![]() |
提出日時 | 2019-12-18 21:43:44 |
言語 | C (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,173 bytes |
コンパイル時間 | 112 ms |
コンパイル使用メモリ | 32,128 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-07 00:51:48 |
合計ジャッジ時間 | 2,304 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 108 WA * 14 |
ソースコード
// yuki 955 ax^2+bx+c=0 // 2019.12.18 bal4u #include <stdio.h> #include <ctype.h> #include <stdlib.h> #include <math.h> typedef long long ll; typedef long double Lf; int getchar_unlocked(void); #define gc() getchar_unlocked() int in() { // 整数の入力 int n = 0; int c; do c = gc(); while (isspace(c)); if (c == '-') { c = gc(); do n = 10*n + (c & 0xf), c = gc(); while (c >= '0'); return -n; } do n = 10*n + (c & 0xf), c = gc(); while (c >= '0'); return n; } void pr(int n, Lf x1, Lf x2) { printf("%d\n", n); if (n == 1) printf("%.16Lf\n", x1); else if (n == 2) { if (x1 <= x2) printf("%.16Lf\n%.16Lf\n", x1, x2); else printf("%.16Lf\n%.16Lf\n", x2, x1); } exit(0); } int main() { int a, b, c; a = in(), b = in(), c = in(); if (a == 0) { if (b == 0 && c == 0) pr(-1, 0, 0); else if (b == 0) pr(0, 0, 0); else pr(1, -(Lf)c/b, 0); } else if (c == 0) pr(2, 0, -(Lf)b/a); else { ll d = (ll)b*b - 4*(ll)a*c; if (d < 0) pr(0, 0, 0); else if (d == 0) pr(1, -(Lf)b/(2*a), 0); else { Lf x, t = sqrtl((Lf)d); if (b >= 0) x = (-b-t)/(2*a); else x = (-b+t)/(2*a); pr(2, x, (Lf)c/a/x); } } return 0; }