結果

問題 No.527 ナップサック容量問題
ユーザー りあん
提出日時 2016-05-23 22:56:27
言語 C#
(csc 2.8.2.62916)
結果
AC  
実行時間 53 ms
コード長 1,534 Byte
コンパイル時間 621 ms
使用メモリ 17,664 KB
最終ジャッジ日時 2019-08-21 03:58:29

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
0_sample_01.in AC 31 ms
13,560 KB
0_sample_02.in AC 32 ms
15,612 KB
0_sample_03.in AC 31 ms
15,616 KB
hand_01.in AC 32 ms
15,620 KB
hand_02.in AC 30 ms
13,572 KB
random_01.in AC 39 ms
15,624 KB
random_02.in AC 48 ms
11,540 KB
random_03.in AC 46 ms
17,664 KB
random_04.in AC 38 ms
13,592 KB
random_05.in AC 33 ms
15,624 KB
random_06.in AC 49 ms
15,608 KB
random_07.in AC 44 ms
17,664 KB
random_08.in AC 40 ms
15,624 KB
random_09.in AC 50 ms
15,612 KB
random_10.in AC 37 ms
13,568 KB
random_11.in AC 41 ms
13,584 KB
random_12.in AC 31 ms
13,576 KB
random_13.in AC 40 ms
13,576 KB
random_14.in AC 40 ms
13,580 KB
random_15.in AC 32 ms
13,592 KB
random_16.in AC 38 ms
17,660 KB
random_17.in AC 52 ms
15,612 KB
random_18.in AC 44 ms
11,532 KB
random_19.in AC 51 ms
13,592 KB
random_20.in AC 35 ms
15,620 KB
random_21.in AC 45 ms
15,612 KB
random_22.in AC 44 ms
15,620 KB
random_23.in AC 44 ms
15,620 KB
random_24.in AC 43 ms
15,628 KB
random_25.in AC 53 ms
15,616 KB
random_26.in AC 33 ms
13,568 KB
random_27.in AC 42 ms
15,616 KB
random_28.in AC 42 ms
15,612 KB
random_29.in AC 40 ms
13,576 KB
random_30.in AC 41 ms
11,548 KB
random_31.in AC 42 ms
13,572 KB
random_32.in AC 31 ms
15,612 KB
random_33.in AC 40 ms
15,612 KB
random_34.in AC 43 ms
15,616 KB
random_35.in AC 41 ms
13,584 KB
テストケース一括ダウンロード
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 2.8.2.62916 (2ad4aabc)
Copyright (C) Microsoft Corporation. All rights reserved.

ソースコード

diff #
using System;
using System.Collections.Generic;
using System.Linq;
using System.IO;
using System.Text;

class Program
{
    const int M = 1000000007;
    static void Main()
    {
        var sw = new StreamWriter(Console.OpenStandardOutput()) { AutoFlush = false };
        var sc = new Scan();
        int n = sc.Int;
        int lim = 100010;
        var dp = new int[lim];
        for (int i = 1; i < lim; i++)
            dp[i] = M;
        
        for (int i = 0; i < n; i++)
        {
            int v, w;
            sc.Multi(out v, out w);
            for (int j = lim - 1; j > v; j--)
                dp[j] = Math.Min(dp[j], dp[j - v] + w);
            for (int j = v; j > 0; j--)
                dp[j] = Math.Min(dp[j], w);
        }
        int V = sc.Int;
        sw.WriteLine(dp[V] > 0 ? dp[V] : 1);
        sw.WriteLine(dp[V + 1] < M ? (dp[V + 1] - 1).ToString() : "inf");
        sw.Flush();
    }
}
class Scan
{
    public int Int { get { return int.Parse(Str); } }
    public long Long { get { return long.Parse(Str); } }
    public string Str { get { return Console.ReadLine().Trim(); } }
    public int[] IntArr { get { return StrArr.Select(int.Parse).ToArray(); } }
    public long[] LongArr { get { return StrArr.Select(long.Parse).ToArray(); } }
    public string[] StrArr { get { return Str.Split(); } }
    public void Multi(out int a, out int b) { var arr = IntArr; a = arr[0]; b = arr[1]; }
    public void Multi(out int a, out int b, out int c) { var arr = IntArr; a = arr[0]; b = arr[1]; c = arr[2]; }
}
0