LeetCode(120) Triangle
2015-11-14 15:37
357 查看
题目
Given a triangle, find the minimum path sum from top to bottom. Each step you may move to adjacent numbers on the row below.For example, given the following triangle
The minimum path sum from top to bottom is 11 (i.e., 2 + 3 + 5 + 1 = 11).
分析
本题类似于之前的一个障碍物的题目,用到动态规划的思想;分析第i层的第k个顶点的最小路径长度表示为
f(i,k),则f(i,k)=minf(i−1,k),f(i−1,k−1)+d(i,k); (注意每行的首尾边界需要特殊处理)
其中d(i,k)表示原来三角形数组里的第i行第k列的元素。
则可以求得从第一行到最终到第rows−1行第k个元素的最小路径长度,最后再比较第rows−1行中所有元素的路径长度大小,求得最小值。
题目要求:空间复杂度不要超过n。
AC代码
class Solution { public: int minimumTotal(vector<vector<int>>& triangle) { if (triangle.empty()) return 0; int rows = triangle.size(); //动态规划,由于空间复杂度要求,现利用原始二维数组triangle改为存储当前(i,j)位置的最小和 for (int i = 1; i < rows; ++i) { int cols = triangle[i].size(); for (int j = 0; j < cols; ++j) { //本行的第一个元素 if (0 == j) { triangle[i][j] = triangle[i][j] + triangle[i - 1][j]; } //本行的最后一个元素 else if (j == cols - 1) { triangle[i][j] += triangle[i - 1][j - 1]; } else{ triangle[i][j] = min(triangle[i][j] + triangle[i][j - 1], triangle[i][j] + triangle[i - 1][j - 1]); }//else }//for }//for //最小路径和为最后一行的最小值 int minSum = triangle[rows - 1][0]; for (int j = 0; j < triangle[rows - 1].size(); ++j) { if (minSum > triangle[rows - 1][j]) minSum = triangle[rows - 1][j]; }//for return minSum; } };
GitHub测试程序源码
相关文章推荐
- 运费模版源码(.net)
- 空间索引
- 怎样防止重复发送 Ajax 请求?
- 导出Excel(终极版)
- 开方最快算法
- 清理缓存和计算缓存内容大小
- 九度OJ 1255:骰子点数概率 (递归、DP)
- 九度OJ 1255:骰子点数概率 (递归、DP)
- VC++ 通过ADO方式连接SQLServer20XX出现sqlserver 不存在或者拒绝连接错误
- NOIP2015PJ T3,T4题解
- k-d tree算法的研究
- VI使用
- Git学习笔记
- Java基础
- Objective-C多态,动态类型识别,动态绑定
- Java 枚举 String-String
- 毫秒必争,前端网页性能最佳实践
- (转) java排列组合算法(n选m)
- iOS UITableView head view与cell view文字垂直居中,文字右对齐
- c/c++素数距离问题