Algorithms-64.Minimum Path Sum
来源:互联网 发布:尚学堂java视频教程 编辑:程序博客网 时间:2024/06/11 11:15
思路:动态规划。f(x,y)=(x,y)+Min(f(x+1,y),f(x,y+1)),只是用这个递归会导致Time Limit Exceeded,再递归查询的同时建立一个hashmap,存储查询过的f(x,y),避免重复查询。
public class Solution { public int minPathSum(int[][] grid) { int xl=grid.length; int yl=grid[0].length; Map<String, Integer> map=new HashMap<String, Integer>(); return f(grid,0,0,xl,yl,map); } public int f(int[][] grid,int x,int y,int xl,int yl,Map<String, Integer> map){ String coordinate=x+","+y; if (map.get(coordinate)==null) {if (x>=xl||y>=yl) {return -1;}else {int xv=f(grid,x+1,y,xl,yl,map);int yv=f(grid,x,y+1,xl,yl,map); int v=0; if (xv<0) {v=yv;}else if (yv<0) {v=xv;}else if (xv>yv){v=yv;}else {v=xv;}int value=grid[x][y]+(v<0?0:v);map.put(coordinate, value);return value;}} return map.get(coordinate); }}
耗时:440ms,下游。
0 0
- Algorithms-64.Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64.Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 64. Minimum Path Sum
- 231 - power of two
- ISP于IAP的区别
- poj 1742 Coins(多重背包)
- C# WinForm判断程序是否运行,且只能运行单个实例
- int main(int argc, char **argv)的使用方法。
- Algorithms-64.Minimum Path Sum
- 抓包函数-pcap_next
- MFC对Excel数据进行读取
- Kali Linux hosts and host.conf
- Spring学习笔记三(AOP中的那些事)
- HDU - 3715 Go Deeper (二分 + 2-SAT)
- tableView联动
- 编写Socket客户端和服务器程序,客户端发送一个包含多个数字的字符串给服务器,服务器排序后返回给客户端,要求服务器能连续不断地服务。
- 线程(2)-----线程池