結果

問題 No.1199 お菓子配り-2
コンテスト
ユーザー ID 21712
提出日時 2026-06-04 17:21:50
言語 Go
(1.26.1)
コンパイル:
env GOCACHE=/tmp go build _filename_
実行:
./Main
結果
AC  
実行時間 479 ms / 1,000 ms
コード長 1,162 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 11,594 ms
コンパイル使用メモリ 283,040 KB
実行使用メモリ 7,972 KB
最終ジャッジ日時 2026-06-04 17:22:23
合計ジャッジ時間 28,654 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
純コード判定待ち
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 45
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

package main

import . "fmt"
import . "os"
import bf "bufio"

// まさかIOでTLE...ですか!?

func main() {
	rd:=bf.NewReader(Stdin)
	var n,m int
	Fscan(rd,&n,&m)
	dp := make([]int, 2)
	for i := 0; i < n; i++ {
		sum := 0
		for k := 0; k < m; k++ {
			var a int
			Fscan(rd,&a)
			sum += a
		}
		dp[0],dp[1] = max(dp[0],dp[1]+sum,sum),max(dp[1],dp[0]-sum)
	}
	Println(max(dp[0],dp[1]))
}

/*
考察

これ子供の区別は必要か?と思ったら
どうもコンテスト時は同じ問題タイトルで難易度の違う問題が出ていたようで
フォーマットの統一感を出すためなのかもしれない
他の難易度の問題では区別して計算する必要があるのだと思う(他の問題はまだ見てないけど)

i番目を取る取らないのシンプルなDP問題ぽい

DP[i番目][i番目時点での幸せ度最大の食べた回数の偶奇] = 最大の幸せ度
で
DP[i][奇数] = max(DP[i-1][奇数], DP[i-1][偶数] + sum(Ai1..AiM), sum(Ai1..AiM))
DP[i][偶数] = max(DP[i-1][偶数], DP[i-1][奇数] - sum(Ai1..AiM))
で更新かな

もうすこし強いサンプルが欲しかったかも

*/
0