当前位置: 首页 > article >正文

力扣动态规划-16【算法学习day.110】

前言

###我做这类文章一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?建议灵神的题单和代码随想录)和记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.三角形最小路径和

题目链接:120. 三角形最小路径和 - 力扣(LeetCode)

题面:

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];
    }
}

后言

上面是动态规划相关的习题,共勉

 

 


http://www.kler.cn/a/529142.html

相关文章:

  • LeetCode:494.目标和
  • 计算机网络一点事(24)
  • C# 实现 “Hello World” 教程
  • pytorch实现文本摘要
  • 87.(3)攻防世界 web simple_php
  • 计算机组成原理——存储系统(一)
  • 《苍穹外卖》项目学习记录-Day5在Java中操作Redis_Spring Data Redis
  • torch numpy seed使用方法
  • Easy系列PLC尺寸测量功能块(激光微距应用)
  • 2007-2019年各省科学技术支出数据
  • A4988一款常用的步进电机驱动芯片
  • 项目架构调整,切换版本并发布到中央仓库
  • Java篇之继承
  • Flink报错Caused by: java.io.FileNotFoundException: /home/wc.txt
  • Ubuntu16.04编译安装Cartographer 1.0版本
  • NoteGen:记录、写作与AI融合的跨端笔记应用
  • Java开发vscode环境搭建(二)-项目启动补充
  • XML DOM 获取节点值
  • S4 HANA给科目分配允许记账的税码
  • FLTK - FLTK1.4.1 - demo - arc
  • 【愚公系列】《循序渐进Vue.js 3.x前端开发实践》042-Vite工具入门
  • Python之Excel操作 - 读取数据
  • neo4j初识
  • ASP.NET Core自定义 MIME 类型配置
  • 415.字符串相加
  • [SAP ABAP] ALV报表练习3