Codeforces Round #464 (Div. 2) - F. Cutlet

問題リンク

難しかったので自分用メモ

これベースに理解した。

カツレツの両面を0と1とすると

dp[i][j][k] := i番目の区間まで見た時、今面kを焼いていて、0をj時間焼いたときのひっくり返す最小値

あとは区間の長さの分だけ自由な時間0の面を焼くことができるので、それに合わして上のツイートのように遷移していけばいい

ついでにslide最小値は関数にした。

提出コード

codeforces.com

まとめ

これ理解するのにほぼ半日使っちゃった…

こういうのすらっとできるようになりたいね