結果

問題 No.1015 おつりは要らないです
コンテスト
ユーザー Rho
提出日時 2020-04-03 21:44:02
言語 C++14
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++14 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
WA  
実行時間 -
コード長 1,014 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,170 ms
コンパイル使用メモリ 184,200 KB
実行使用メモリ 6,272 KB
最終ジャッジ日時 2026-03-24 09:08:31
合計ジャッジ時間 5,077 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge1_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 21 WA * 12
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include "bits/stdc++.h"
using namespace std;
#define rep(i,n) for(int i=0;i<n;i++)
#define int long long
int a[100006];
signed main() {
	int n, x, y, z; cin >> n >> x >> y >> z;
	rep(i, n) {
		cin >> a[i];
		a[i] = a[i] / 1000 + 1;
	}

	rep(i, n) {
		int t = a[i] / 10;
		if (z >= t) {
			z -= t;
			a[i] %= 10;
		}
		else {
			a[i] -= z * 10;
			z = 0;
		}
	}
	rep(i, n) {
		int t = a[i] / 5;
		if (y >= t) {
			y -= t;
			a[i] %= 5;
		}
		else {
			a[i] -= 5 * y;
			y = 0;
		}
	}

	sort(a, a + n);
	reverse(a, a + n);
	rep(i, n) {
		int t = (a[i]+9) / 10;
		if (z >= t) {
			z -= t;
			a[i] = 0;
		}
		else {
			a[i] -= z * 10;
			z = 0;
		}
	}
	sort(a, a + n);
	reverse(a, a + n);
	rep(i, n) {
		int t = (a[i]+4) / 5;
		if (y >= t) {
			y -= t;
			a[i] = 0;
		}
		else {
			a[i] -= 5 * y;
			y = 0;
		}
	}
	sort(a, a + n);
	reverse(a, a + n);
	rep(i, n) {
		if (x >= a[i]) {
			x -= a[i];
			a[i] = 0;
		}
		else {
			a[i] -= x;
			x = 0;
		}
	}
	sort(a, a + n);
	if (a[n - 1])puts("No");
	else puts("Yes");
}
0