結果

問題 No.1015 おつりは要らないです
ユーザー bluemeganebluemegane
提出日時 2021-05-03 23:04:38
言語 C#(csc)
(csc 3.9.0)
結果
AC  
実行時間 323 ms / 2,000 ms
コード長 2,991 bytes
コンパイル時間 2,040 ms
コンパイル使用メモリ 114,844 KB
実行使用メモリ 33,536 KB
最終ジャッジ日時 2024-07-22 13:17:24
合計ジャッジ時間 9,780 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 26 ms
17,664 KB
testcase_01 AC 25 ms
17,792 KB
testcase_02 AC 25 ms
17,664 KB
testcase_03 AC 25 ms
17,920 KB
testcase_04 AC 25 ms
17,920 KB
testcase_05 AC 26 ms
17,792 KB
testcase_06 AC 25 ms
17,664 KB
testcase_07 AC 26 ms
17,920 KB
testcase_08 AC 28 ms
17,792 KB
testcase_09 AC 26 ms
17,792 KB
testcase_10 AC 308 ms
32,000 KB
testcase_11 AC 310 ms
32,128 KB
testcase_12 AC 294 ms
31,616 KB
testcase_13 AC 306 ms
31,744 KB
testcase_14 AC 323 ms
32,384 KB
testcase_15 AC 298 ms
31,872 KB
testcase_16 AC 309 ms
31,616 KB
testcase_17 AC 316 ms
32,256 KB
testcase_18 AC 304 ms
31,744 KB
testcase_19 AC 304 ms
31,872 KB
testcase_20 AC 260 ms
31,488 KB
testcase_21 AC 255 ms
31,744 KB
testcase_22 AC 260 ms
31,616 KB
testcase_23 AC 249 ms
31,232 KB
testcase_24 AC 262 ms
31,872 KB
testcase_25 AC 256 ms
31,616 KB
testcase_26 AC 259 ms
31,616 KB
testcase_27 AC 256 ms
31,360 KB
testcase_28 AC 251 ms
31,488 KB
testcase_29 AC 262 ms
31,744 KB
testcase_30 AC 25 ms
17,664 KB
testcase_31 AC 67 ms
27,392 KB
testcase_32 AC 69 ms
27,776 KB
testcase_33 AC 93 ms
33,536 KB
testcase_34 AC 27 ms
17,664 KB
testcase_35 AC 26 ms
17,920 KB
testcase_36 AC 26 ms
17,920 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc)
Copyright (C) Microsoft Corporation. All rights reserved.

ソースコード

diff #

using static System.Math;
using System.Collections.Generic;
using System;

public class PriorityQueue<T> where T : IComparable
{
	private IComparer<T> _comparer = null;
	private int _type = 0;
	private T[] _heap;
	private int _sz = 0;
	private int _count = 0;
	public PriorityQueue(int maxSize, IComparer<T> comparer)
	{
		_heap = new T[maxSize];
		_comparer = comparer;
	}
	public PriorityQueue(int maxSize, int type = 0)
	{
		_heap = new T[maxSize];
		_type = type;
	}
	private int Compare(T x, T y)
	{
		if (_comparer != null) return _comparer.Compare(x, y);
		return _type == 0 ? x.CompareTo(y) : y.CompareTo(x);
	}
	public void Push(T x)
	{
		_count++;
		var i = _sz++;
		while (i > 0)
		{
			var p = (i - 1) / 2;
			if (Compare(_heap[p], x) <= 0) break;
			_heap[i] = _heap[p];
			i = p;
		}
		_heap[i] = x;
	}
	public T Pop()
	{
		_count--;
		T ret = _heap[0];
		T x = _heap[--_sz];
		int i = 0;
		while (i * 2 + 1 < _sz)
		{
			int a = i * 2 + 1;
			int b = i * 2 + 2;
			if (b < _sz && Compare(_heap[b], _heap[a]) < 0) a = b;
			if (Compare(_heap[a], x) >= 0) break;
			_heap[i] = _heap[a];
			i = a;
		}
		_heap[i] = x;
		return ret;
	}
	public int Count() => _count;
	public T Peek() => _heap[0];
	public bool Contains(T x)
	{
		for (int i = 0; i < _sz; i++) if (x.Equals(_heap[i])) return true;
		return false;
	}
	public void Clear()
	{
		while (this.Count() > 0) this.Pop();
	}
	public IEnumerator<T> GetEnumerator()
	{
		var ret = new List<T>();
		while (this.Count() > 0)
		{
			ret.Add(this.Pop());
		}
		foreach (var r in ret)
		{
			this.Push(r);
			yield return r;
		}
	}
	public T[] ToArray()
	{
		T[] array = new T[_sz];
		int i = 0;
		foreach (var r in this)
		{
			array[i++] = r;
		}
		return array;
	}
}


public class Hello
{
	public static int n, x, y, z;
    static void Main()
    {
        string[] line = Console.ReadLine().Trim().Split(' ');
         n = int.Parse(line[0]);
        x = int.Parse(line[1]);
        y = int.Parse(line[2]);
        z = int.Parse(line[3]);
        line = Console.ReadLine().Trim().Split(' ');
        var a = Array.ConvertAll(line, int.Parse);
		getAns(a);
    }
	static void getAns (int[] a)
    {
		var pq = new PriorityQueue<int>(n, 1);
		for (int i = 0; i < n; i++) pq.Push(a[i]);
        while (pq.Count() > 0)
        {
			var t = pq.Pop();
			if (z > 0)
			{
				if (t >= 10000)
				{
					var t1 = t / 10000;
					var t2 = Min(z, t1);
					z -= t2;
					t -= t2 * 10000;
					pq.Push(t);
				}
				else z--;
			}
			else if (y > 0)
            {
				if (t >= 5000)
				{
					var t1 = t / 5000;
					var t2 = Min(y, t1);
					y -= t2;
					t -= t2 * 5000;
					pq.Push(t);
				}
				else y--;
			}
			else if (x > 0)
            {
				if (t >= 1000)
				{
					var t1 = t / 1000;
					var t2 = Min(x, t1);
					x -= t2;
					t -= t2 * 1000;
					pq.Push(t);
				}
				else x--;
			}
			else
            {
                Console.WriteLine("No");
				return;
            }

		}
        Console.WriteLine("Yes");
    }
}
0