結果

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

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
0_sample_01.in AC 32 ms
10,572 KB
0_sample_02.in AC 35 ms
10,572 KB
0_sample_03.in AC 33 ms
10,584 KB
hand_01.in AC 34 ms
10,576 KB
hand_02.in AC 31 ms
10,576 KB
random_01.in AC 43 ms
10,588 KB
random_02.in AC 55 ms
10,608 KB
random_03.in AC 51 ms
10,608 KB
random_04.in AC 42 ms
10,588 KB
random_05.in AC 33 ms
10,568 KB
random_06.in AC 53 ms
10,604 KB
random_07.in AC 49 ms
10,600 KB
random_08.in AC 46 ms
10,592 KB
random_09.in AC 56 ms
10,612 KB
random_10.in AC 40 ms
10,588 KB
random_11.in AC 46 ms
10,600 KB
random_12.in AC 34 ms
10,580 KB
random_13.in AC 44 ms
10,592 KB
random_14.in AC 47 ms
10,588 KB
random_15.in AC 34 ms
10,568 KB
random_16.in AC 45 ms
10,592 KB
random_17.in AC 62 ms
10,620 KB
random_18.in AC 53 ms
10,604 KB
random_19.in AC 58 ms
10,620 KB
random_20.in AC 37 ms
10,580 KB
random_21.in AC 50 ms
10,596 KB
random_22.in AC 48 ms
10,600 KB
random_23.in AC 48 ms
10,604 KB
random_24.in AC 46 ms
10,592 KB
random_25.in AC 59 ms
10,620 KB
random_26.in AC 35 ms
10,580 KB
random_27.in AC 44 ms
10,596 KB
random_28.in AC 46 ms
10,596 KB
random_29.in AC 46 ms
10,592 KB
random_30.in AC 47 ms
10,596 KB
random_31.in AC 47 ms
10,592 KB
random_32.in AC 34 ms
10,572 KB
random_33.in AC 45 ms
10,596 KB
random_34.in AC 46 ms
10,592 KB
random_35.in AC 45 ms
10,588 KB
テストケース一括ダウンロード
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.3.1-beta4-19462-11 (66a912c9)
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