結果

問題 No.5 数字のブロック
ユーザー eagleeagle
提出日時 2022-05-26 15:27:40
言語 Java
(openjdk 23)
結果
AC  
実行時間 459 ms / 5,000 ms
コード長 862 bytes
コンパイル時間 2,267 ms
コンパイル使用メモリ 78,532 KB
実行使用メモリ 47,636 KB
最終ジャッジ日時 2024-09-20 15:01:11
合計ジャッジ時間 10,294 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 34
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		// TODO 自動生成されたメソッド・スタブ
		Scanner sc = new Scanner(System.in);
		//大きな箱の幅
		int L = sc.nextInt();
		//ブロックの数
		int N = sc.nextInt();
		//各ブロックの幅
		int[] W = new int[N];
		for(int i = 0; i < N; i++) {
			W[i] = sc.nextInt();
		}
		//配列Wを小さい順に並び替える
		for(int i = 0; i < N - 1; i++) {
			for(int j = i; j < N; j++) {
				if(W[i] > W[j]) {
					int num = W[i];
					W[i] = W[j];
					W[j] = num;
				}
			}
		}
		//大きな箱に小さい箱から順に入れていく
		int w = 0; //現在の幅
		int ans = 0; //大きな箱に入れた箱の個数
		for(int i = 0; i < N; i++) {
			if(w + W[i] > L) {
				break;
			}
			w += W[i];
			ans++;
		}
		System.out.println(ans);
	}
}
0