結果
問題 |
No.955 ax^2+bx+c=0
|
ユーザー |
|
提出日時 | 2020-04-04 22:26:08 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 175 ms / 2,000 ms |
コード長 | 1,429 bytes |
コンパイル時間 | 2,407 ms |
コンパイル使用メモリ | 89,272 KB |
実行使用メモリ | 55,556 KB |
最終ジャッジ日時 | 2024-07-03 07:49:01 |
合計ジャッジ時間 | 22,970 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 122 |
ソースコード
import java.math.BigDecimal; import java.math.MathContext; import java.util.Arrays; import java.util.Scanner; class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); BigDecimal a = scanner.nextBigDecimal(), b = scanner.nextBigDecimal(), c = scanner.nextBigDecimal(); if (a.equals(BigDecimal.ZERO)) { if (b.equals(BigDecimal.ZERO)) { if (c.equals(BigDecimal.ZERO)) System.out.print(-1); else System.out.print(0); } else { System.out.println(1); System.out.print(BigDecimal.ZERO.subtract(c).divide(b, MathContext.DECIMAL128).toPlainString()); } } else { BigDecimal d = b.multiply(b).subtract(a.multiply(c).multiply(new BigDecimal(4))); if (d.compareTo(BigDecimal.ZERO) == 1) { BigDecimal[] e = new BigDecimal[2]; e[0] = BigDecimal.ZERO.subtract(d.sqrt(MathContext.DECIMAL128)).subtract(b).divide(a.multiply(new BigDecimal(2)), MathContext.DECIMAL128); e[1] = d.sqrt(MathContext.DECIMAL128).subtract(b).divide(a.multiply(new BigDecimal(2)), MathContext.DECIMAL128); Arrays.sort(e); System.out.print(2 + "\n" + e[0].toPlainString() + '\n' + e[1].toPlainString()); } else if (d.equals(BigDecimal.ZERO)) { System.out.println(1); System.out.print(BigDecimal.ZERO.subtract(b).divide(a.multiply(new BigDecimal(2)), MathContext.DECIMAL128)); } else System.out.print(0); } } }