結果
問題 |
No.955 ax^2+bx+c=0
|
ユーザー |
![]() |
提出日時 | 2019-12-18 22:11:19 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 2,000 ms |
コード長 | 1,218 bytes |
コンパイル時間 | 342 ms |
コンパイル使用メモリ | 32,128 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-09-18 22:14:48 |
合計ジャッジ時間 | 3,051 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 122 |
ソースコード
// 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; 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, double x1, double 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, -(double)c/b, 0); } else if (c == 0) { if (b == 0) pr(1, 0, 0); else pr(2, 0, -(double)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, -(double)b/(2*a), 0); else { double x, t = sqrt((double)d); if (b >= 0) x = (-b-t)/(2*a); else x = (-b+t)/(2*a); pr(2, x, (double)c/a/x); } } return 0; }