前言
###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!
习题
1.三角形最小路径和
题目链接: 120. 三角形最小路径和 - 力扣(LeetCode)
题面:
java
class Solution {
List<List<Integer>> triangle;
int n,m;
int[][] map;
int min = Integer.MAX_VALUE;
int[][] f;
int[][] flag;
public int minimumTotal(List<List<Integer>> triangle) {
this.triangle = triangle;
n = triangle.size();
m = triangle.get(n-1).size();
map = new int[n][m];
f = new int[n][m];
flag = new int[n][m];
for(int[] arr:flag){
Arrays.fill(arr,100000);
}
for(int i = 0;i<n;i++){
List<Integer> list = triangle.get(i);
int index = 0;
for(int a:list){
map[i][index++] = a;
}
}
List<Integer> list = triangle.get(n-1);
for(int i = 0;i<m;i++){
int blog = recursion(n-1,i);
min = Math.min(min,blog);
}
return min;
}
public int recursion(int x,int y){
if(flag[x][y]!=100000){
return flag[x][y];
}
if(x==0&&y==0){
return map[x][y];
}
int a = 0;
if(x-1>=0&&y-1>=0&&(x-1)>(y-1)){
a = Math.min(recursion(x-1,y),recursion(x-1,y-1));
}else if(x-1>=0&&y>=0&&x-1>=y){
a = recursion(x-1,y);
}else if(x-1>=0&&y-1>=0){
a = recursion(x-1,y-1);
}else{
return 100000000;
}
if(a==100000000||a==200000000){
return 100000000;
}
return flag[x][y] = a+map[x][y];
}
}
后言
上面是动态规划相关的习题,共勉