[leetcode] Maximal Square
2015-06-03 16:40
197 查看
动态规划,dp[i][j]代表以i,j为右下角的正方形的最长边长。代码如下:
利用回滚数组可将空间优化到一维!
若输入matrix类型为int,dp数组可重用matrix,空间复杂度可优化到常数空间。
int maximalSquare(vector<vector<char>>& matrix) { int result = 0; if(matrix.empty()) return result; const int n = matrix.size(); const int m = matrix[0].size(); vector<vector<int> > dp(n + 1, vector<int>(m + 1, 0)); for(int i = 0; i < n; ++i) for(int j = 0; j < m; ++j){ if(matrix[i][j] == '1'){ dp[i + 1][j + 1] = min(dp[i][j], min(dp[i + 1][j], dp[i][j + 1])) + 1; result = max(result, dp[i + 1][j + 1]); } } return result * result; }
利用回滚数组可将空间优化到一维!
若输入matrix类型为int,dp数组可重用matrix,空间复杂度可优化到常数空间。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C#数据结构与算法揭秘二
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C++联合体转换成C#结构的实现方法
- C#实现的算24点游戏算法实例分析
- C++编写简单的打靶游戏
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- C++中调用Lua函数实例