結果

問題 No.1199 お菓子配り-2
コンテスト
ユーザー ID 21712
提出日時 2026-06-04 17:19:16
言語 Go
(1.26.1)
コンパイル:
env GOCACHE=/tmp go build _filename_
実行:
./Main
結果
TLE  
実行時間 -
コード長 1,057 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 14,803 ms
コンパイル使用メモリ 278,164 KB
実行使用メモリ 13,056 KB
最終ジャッジ日時 2026-06-04 17:20:31
合計ジャッジ時間 20,656 ms
ジャッジサーバーID
(参考情報)
judge2_1 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other TLE * 2 -- * 43
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

package main

import . "fmt"

func main() {
	var n,m int
	Scan(&n,&m)
	dp := make([]int, 2)
	for i := 0; i < n; i++ {
		sum := 0
		for k := 0; k < m; k++ {
			var a int
			Scan(&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