Typical DP Contest

Submission #6350415

Source codeソースコード

package main

import (
	"bufio"
	"fmt"
	"os"
	"strconv"
)

func getScanner(fp *os.File) *bufio.Scanner {
	scanner := bufio.NewScanner(fp)
	scanner.Split(bufio.ScanWords)
	scanner.Buffer(make([]byte, 500001), 500000)
	return scanner
}

func getNextString(scanner *bufio.Scanner) string {
	scanner.Scan()
	return scanner.Text()
}

func getNextInt(scanner *bufio.Scanner) int {
	i, _ := strconv.Atoi(getNextString(scanner))
	return i
}

func getNextInt64(scanner *bufio.Scanner) int64 {
	i, _ := strconv.ParseInt(getNextString(scanner), 10, 64)
	return i
}

func main() {
	fp := os.Stdin
	if len(os.Args) > 1 {
		fp, _ = os.Open(os.Args[1])
	}

	scanner := getScanner(fp)

	writer := bufio.NewWriter(os.Stdout)

	n := getNextInt(scanner)

	max := n*100 + 1
	dp := make([]int, max+1)
	dp[0] = 1
	for i := 0; i < n; i++ {
		p := getNextInt(scanner)
		for ii := max - 1; ii >= p; ii-- {
			dp[ii] |= dp[ii-p]
		}
	}

	ans := 0
	for i := 0; i < max; i++ {
		ans += dp[i]
	}
	fmt.Fprintln(writer, ans)

	writer.Flush()
}

Submission

Task問題 A - コンテスト
User nameユーザ名 ccppjsrb
Created time投稿日時
Language言語 Go (1.6)
Status状態 AC
Score得点 2
Source lengthソースコード長 1074 Byte
File nameファイル名
Exec time実行時間 3 ms
Memory usageメモリ使用量 768 KB

Test case

Set

Set name Score得点 / Max score Cases
All 2 / 2 00,01,02,90,91

Test case

Case name Status状態 Exec time実行時間 Memory usageメモリ使用量
00 AC 1 ms 640 KB
01 AC 2 ms 640 KB
02 AC 3 ms 768 KB
90 AC 1 ms 640 KB
91 AC 1 ms 640 KB