結果
問題 | No.1738 What's in the box? |
ユーザー |
![]() |
提出日時 | 2021-11-12 22:19:32 |
言語 | Java (openjdk 23) |
結果 |
AC
|
実行時間 | 259 ms / 2,000 ms |
コード長 | 705 bytes |
コンパイル時間 | 2,970 ms |
コンパイル使用メモリ | 79,736 KB |
実行使用メモリ | 55,532 KB |
最終ジャッジ日時 | 2024-11-25 19:20:31 |
合計ジャッジ時間 | 18,163 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 70 |
ソースコード
import java.util.Scanner; public class Main { public static void main(String[] args) { try (Scanner sc = new Scanner(System.in)) { int N = sc.nextInt(), M = sc.nextInt(); int[] W = new int[N]; for (int i = 0;i < N;++ i) W[i] = sc.nextInt(); int[] A = new int[N]; if (M != 0) { int gcd = 0; for (int i : W) gcd = gcd(gcd, i); int sum = 0; for (int i = 0;i < N;++ i) sum += W[i] /= gcd; for (int i = 0;i < N;++ i) A[i] = M / sum * W[i]; } System.out.print(A[0]); for (int i = 1;i < N;++ i) System.out.print(" " + A[i]); System.out.println(); } } static int gcd(int a, int b) { while(b != 0) if((a %= b) != 0) b %= a; else return b; return a; } }