結果

問題 No.496 ワープクリスタル (給料日前編)
ユーザー myantamyanta
提出日時 2017-06-30 10:24:48
言語 C++11
(gcc 13.3.0)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 837 bytes
コンパイル時間 405 ms
コンパイル使用メモリ 41,856 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-04 20:32:34
合計ジャッジ時間 1,426 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 2 ms
5,248 KB
testcase_02 AC 2 ms
5,248 KB
testcase_03 AC 2 ms
5,248 KB
testcase_04 AC 2 ms
5,248 KB
testcase_05 AC 2 ms
5,248 KB
testcase_06 AC 1 ms
5,248 KB
testcase_07 AC 1 ms
5,248 KB
testcase_08 AC 2 ms
5,248 KB
testcase_09 AC 3 ms
5,248 KB
testcase_10 AC 2 ms
5,248 KB
testcase_11 AC 2 ms
5,248 KB
testcase_12 AC 2 ms
5,248 KB
testcase_13 AC 2 ms
5,248 KB
testcase_14 AC 1 ms
5,248 KB
testcase_15 AC 2 ms
5,248 KB
testcase_16 AC 1 ms
5,248 KB
testcase_17 AC 2 ms
5,248 KB
testcase_18 AC 2 ms
5,248 KB
testcase_19 AC 2 ms
5,248 KB
testcase_20 AC 2 ms
5,248 KB
testcase_21 AC 1 ms
5,248 KB
testcase_22 AC 2 ms
5,248 KB
testcase_23 AC 2 ms
5,248 KB
testcase_24 AC 3 ms
5,248 KB
testcase_25 AC 2 ms
5,248 KB
testcase_26 AC 2 ms
5,248 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:41:30: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   41 |                         scanf("%d%d%d", &c[i].x, &c[i].y, &c[i].c);
      |                         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#include<cstdio>
#include<vector>


using namespace std;
using vi=vector<int>;
using vvi=vector<vi>;


struct c_t
{
	int x, y, c;
};


int min_u(int&m, int v)
{
	if(m>v){
		m=v;
		return 1;
	}
	return 0;
}


int main(void)
{
	int gx, gy, n, f;

	while(scanf("%d%d%d%d", &gx, &gy, &n, &f)==4)
	{
		vector<c_t> c(n);
		vvi dp(gy+1);
		int ans=(gx+gy)*f;

		for(auto&dpe:dp) dpe.assign(gx+1, ans);
		dp[0][0]=0;

		for(int i=0;i<n;i++)
		{
			scanf("%d%d%d", &c[i].x, &c[i].y, &c[i].c);
		}

		for(int i=0;i<n;i++)
		{
			for(int y=gy;y>=0;y--)
			{
				int ny=y+c[i].y;
				if(ny>gy) continue;

				for(int x=gx;x>=0;x--)
				{
					int nx=x+c[i].x;
					if(nx>gx) continue;

					if(min_u(dp[ny][nx], dp[y][x]+c[i].c))
					{
						min_u(ans, dp[ny][nx]+((gy-ny)+(gx-nx))*f);
					}
				}
			}
		}
		printf("%d\n", ans);
	}

	return 0;
}
0