結果

問題 No.3329 Only the Rightest Choice is Right!!!
コンテスト
ユーザー pengin_2000
提出日時 2025-11-01 15:17:13
言語 C
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 24 ms / 1,571 ms
コード長 770 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 157 ms
コンパイル使用メモリ 40,288 KB
最終ジャッジ日時 2026-02-22 13:49:50
ジャッジサーバーID
(参考情報)
judge4 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 74
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include<stdio.h>
int v[3003], w[3003];
int dp[3003][3003];
int ans[3003], aa;
int main()
{
	int n, W;
	scanf("%d %d", &n, &W);
	int i, j, k;
	for (i = 0; i < n; i++)
		scanf("%d", &v[i]);
	for (i = 0; i < n; i++)
		scanf("%d", &w[i]);
	for (j = 0; j <= W; j++)
		dp[n][j] = 0;
	for (i = n - 1; i >= 0; i--)
	{
		for (j = 0; j <= W; j++)
			dp[i][j] = dp[i + 1][j];
		for (j = 0; j + w[i] <= W; j++)
			if (dp[i][j] < v[i] + dp[i + 1][j + w[i]])
				dp[i][j] = v[i] + dp[i + 1][j + w[i]];
	}
	aa = 0;
	int V = dp[0][0], R = 0, f;
	for (k = -1; V > 0;)
	{
		for (i = k + 1; dp[i][R] == V; i++);
		k = i - 1;
		ans[aa++] = k + 1;
		V -= v[k];
		R += w[k];
	}
	printf("%d\n", aa);
	for (i = 0; i < aa - 1; i++)
		printf("%d ", ans[i]);
	printf("%d\n", ans[i]);
	return 0;
}
0