动态规划之“状态机模型”
概述
学过编译原理的同学对于状态机都有一定的了解。
状态机的组成:待选状态,转移条件,状态入口,状态出口。
转化:将状态抽象为点,转移条件抽象为边。
分类
01态(双位状态机)
表示:在一维数组的基础上增加一位,第二维来表示我们备选的状态。
要素:f[i][0]
表示当前状态不选 , f[i][0]
表示当前状态可选
分析: 0/1相当于已经做出了决策,接下来,借助图论的思想考虑转移的手段,也就是走图上的带权边。
LeetCode 198. 打家劫舍
题目描述
你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。
给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。
示例 1:
输入:[1,2,3,1]
输出:4
解释:偷窃 1 号房屋 (金额 = 1) ,然后偷窃 3 号房屋 (金额 = 3)。
偷窃到的最高金额 = 1 + 3 = 4 。
示例 2:
输入:[2,7,9,3,1]
输出:12
解释:偷窃 1 号房屋 (金额 = 2), 偷窃 3 号房屋 (金额 = 9),接着偷窃 5 号房屋 (金额 = 1)。
偷窃到的最高金额 = 2 + 9 + 1 = 12 。
提示:
- 1 < = n u m s . l e n g t h < = 100 {1 <= nums.length <= 100} 1