算法训练第四十五天 | LeetCode 70、322、279背包问题

news2024/11/19 7:36:12

LeetCode 70爬楼梯

题目简析:

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

思路分析:

用完全背包的思路来做,见注释

    //普通dp
    public int climbStairs(int n) {
        int[]dp = new int[2];
        dp[0] = 1;
        dp[1] = 1;
        //遍历顺序(顺
        for (int i = 2; i <= n; i++) {
            int way = dp[0] + dp[1];
            dp[0] = dp[1];
            dp[1] = way;
        }
        return dp[1];
    }


    //完全背包做法
    //如果求组合数就是外层for循环遍历物品,内层for遍历背包。
    //如果求排列数就是外层for遍历背包,内层for循环遍历物品。
    public int climbStairs(int n) {
        //用完全背包的思路来做
        //几种方法;总和
        //dp[i]:到达i阶梯的方法有dp[i]种
        int []dp = new int[n+1];
        dp[0] = 1;
        //这是排列问题:1 + 2  跟2 + 1是两种方法
        //如果求排列数就是外层for遍历背包,内层for循环遍历物品。
        //这里的背包就是有几级台阶
        for (int i = 1; i <= n; i++) {
            //这里的物品就是:每次走1步还是2步,因此从1开始
            for (int j = 1; j <= 2; j++) {
                //i-j>=0:确保阶梯数大于可走步数
                if(i-j>=0)
                    //不取:dp[i],取:dp[i-w]
                    //j是1的话 dp[i]是由dp[i-1]的方法加出来的
                    //j是2的话 dp[i]是由dp[i-2]的方法加出来的
                    dp[i] += dp[i-j];
            }
        }
        return dp[n];
    }

LeetCode 322零钱兑换

题目简析:

给你一个整数数组 coins ,表示不同面额的硬币;

以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。

如果没有任何一种硬币组合能组成总金额,返回 -1 。

思路分析:

做了这么多题目,我觉得需要在平时做题的时候填多一个思考的点,就是遍历顺序遍历的到底是什么

    public int coinChange(int[] coins, int amount) {
        int max = Integer.MAX_VALUE;
        int len = coins.length;
        //dp[i]:凑成i硬币所需要的最少硬币个数为dp[i]
        int []dp = new int[amount+1];
        //因为求最少,所以用最大
        Arrays.fill(dp,max);
        //需要单独初始化一下0,根据dp含义
        dp[0] = 0;
        //遍历物品----零钱coins[i]
        for (int i = 0; i < len; i++) {
            //遍历背包----凑成j最少需要多少个数的硬币
            for (int j = coins[i]; j <= amount; j++) {
                //什么时候开始选择?
                if (dp[j - coins[i]] != max) {
                    //只有dp[j-coins[i]]不是初始最大值时,该位才有选择的必要
                    //不取:dp[j]
                    //取:dp[j-coins[i]]的最少数,加上所取的这一个,所以+1
                    //本质还是dp[i-w]+v
                    //只不过这里的v是1,因为dp的定义就是用的硬币个数,用了那价值就是1
                    dp[j] = Math.min(dp[j], dp[j - coins[i]] + 1);
                }
            }
        }
        return dp[amount] == max ? -1 : dp[amount];
    }

LeetCode 279完全平方数

题目简析:

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。

思路分析:

这道题的关键点在如何使用平方数来对应背包,贴上随想录的演示图,想清楚当前数是由什么推导出来的就好解决

 

    public int numSquares(int n) {
        int dp[] = new int[n+1];
        //求最少用最大
        int max = Integer.MAX_VALUE;
        Arrays.fill(dp,max);
        //为0的时候没意义
        dp[0] = 0;
        //物品从1开始,无需开方,只需要每一次都用平方去求即可
        //找背包和物品

//        //先包后物
//        //遍历背包----n
//        for (int i = 0; i <= n; i++) {
//            //遍历物品----完全平方数---必须要数小于包容量才能装入
//            for (int j = 1; ; j++) {
//                //即完全平方数不可能超过整数n
//                if(j*j>i){
//                    break;
//                }
//                //取:dp[i-j*j]:j为1的情况下,容量i为8的背包是由凑成dp[7]来推出
//                //若取当前物品,则数量+1(Value)
//                dp[i] = Math.min(dp[i],dp[i-j*j]+1);
//            }
//        }

        //先物后包
        // 遍历物品--物品重量(某个数的平方)不可能超过背包容量
        for (int i = 1; i * i <= n; i++) {
            // 遍历背包---直接用物品重量(平方)去找对应背包位置,如果对应背包位置是物品重量
            //  说明可以直接用此物品重量来装进去,即平方数能直接表示背包容量
            for (int j = i * i; j <= n; j++) {
                if (dp[j - i * i] != max) {
                    dp[j] = Math.min(dp[j], dp[j - i * i] + 1);
                }
            }
        }
        return dp[n];
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/77423.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis框架(四):大众点评项目 基于Redis的短信登录

大众点评项目 基于Session的短信登录需求&#xff1a;基于Redis实现短信验证登录基于Redis的短信登录实战优化为Redis login方法配置拦截器实现双重验证配置类实现异步/排序 拦截结果展示SpringCloud章节复习已经过去&#xff0c;新的章节Redis开始了&#xff0c;这个章节中将会…

【图像处理】DWT图像处理【含Matlab源码 198期】

⛄一、数字图像处理简介 图像处理基础教程链接 1 【基础教程】基于matlab图像处理&#xff08;表示方法数据结构基本格式类型转换读取点运算代数运算&#xff09;【含Matlab源码 834期】 2 【基础教程】基于matlab图像处理&#xff08;读写显示运算转换变换增强滤波分析统计&a…

jvm学习笔记(一)----jvm简史

文章目录1. JVM简单介绍2. java虚拟机介绍1. JVM简单介绍 虚拟机是一种抽象化的计算机&#xff0c;通过在实际的计算机上仿真模拟各种计算机功能来实现的。Java虚拟机有自己完善的硬体架构&#xff0c;如处理器、堆栈、寄存器等&#xff0c;还具有相应的指令系统。Java虚拟机屏…

ASP.NET微信快速开发框架源码【源码分享】

ASP.NET微信快速开发框架源码 微信公众平台快速开发框架源码 需要源码学习&#xff0c;查看文末卡片获取&#xff0c;或私信我。 框架主要技术&#xff1a; ASP.NET MVC5、ASP.NET Identity、Bootstrap、KnockoutJs、Entity Framework等。 主要特色&#xff1a; 1、快速迭代开…

Redis主从复制原理

前面的文章中我们演示过Redis主从配置的操作&#xff0c;可以查看之前的博文Redis主从配置教程。这篇文章主要介绍一下Redis主从复制的工作过程和原理。 Redis复制工作过程 Redis复制的工作过程如上图&#xff0c;主要包含以及几个阶段&#xff1a; 1. 设置IP端口并建立连接 …

C++学习笔记(十九)——stack和queue的模拟实现

容器适配器 deque的简单介绍 stack的模拟实现 queue的模拟实现 容器适配器 适配器:一种设计模式,该种模式是将一个类的接口转换成客户希望的另外一个接口. stack和queue的底层结构 可以看出的是,这两个容器 相比我们之间见过的容器多了一个模板参数,也就是容器类的模板参数,…

数据结构复习+答案

一、选择题&#xff1a;&#xff08;每小题2分&#xff0c;共30分&#xff09; 1、在数据的逻辑结构中&#xff0c;树结构和图结构都是&#xff08; &#xff09; A.非线性结构 B.线性结构 C.动态结构 D.静态结构 2.在一个长度为n的顺序表中插入一个元素的算法的时间复杂度为&…

ThinkPHP文件包含漏洞分析

出品|长白山攻防实验室(ID:A_Tree&#xff09; 0x00 声明 以下内容&#xff0c;来自长白山攻防实验室的A_Tree作者原创&#xff0c;由于传播&#xff0c;利用此文所提供的信息而造成的任何直接或间接的后果和损失&#xff0c;均由使用者本人负责&#xff0c;长白山攻防实验室…

全宇宙最强AI 聊天机器人模型ChatGPT惊艳来袭,你还不上车?居然能写演讲稿和帮忙写代码

目录1、ChatGPT介绍2、ChatGPT如何注册&#xff0c;国内不可用3、VS Code下载安装ChatGPT3.1 打开VS Code找到ChatGPT3.2 ChatGPT 详细安装步骤&#xff1a;3.3 用法3.4 国外模式’ 此模式下&#xff0c;速度会比较稳定&#xff0c;如果有条件&#xff0c;建议使用本模式。 理论…

大数据HDFS凭啥能存下百亿数据?

前言 大家平时经常用的百度网盘存放电影、照片、文档等&#xff0c;那有想过百度网盘是如何存下那么多文件的呢&#xff1f;难到是用一台计算机器存的吗&#xff1f;那得多大磁盘啊&#xff1f;显然不是的&#xff0c;那本文就带大家揭秘。 分布式存储思想 既然一台机器的存储…

Spring 核心与设计思想 · Spring IoC容器 · 控制反转式程序开发 · DI概念

Spring 是什么&#xff1f;一、什么是容器&#xff1f;二、什么是 IoC&#xff1f;2.1 传统程序开发2.2 控制反转式程序开发2.3 对比总结规律三、理解 Spring IoC四、DI 概念说明Spring 是什么&#xff1f; 我们通常说的 Spring 是指 Spring Framework&#xff08;Spring 框架…

【Mysql】知识体系结构构建以及常见考题汇总

【Mysql】知识体系结构构建以及常见考题汇总1、基本SQL知识1.1、D_L语法以及表中常用约束1.2、mysql表列常用数据结构1.3、事务&#xff08;此处展示并发事务问题以及解决方案、实现原理见2.3&#xff09;read uncommitted有脏读问题read committed解决脏读、有不可重复读问题r…

Android基础学习(二十)—— 线程安全

1、Android中线程的常见用法 &#xff08;1&#xff09;继承 Thread class MyThread extends Thread{Overridepublic void run(){//处理具体的逻辑} } new MyThread().start(); //启动此线程//使用匿名类 new Thread(){Overridepublic void run(){//处理具体的逻辑} }.star…

【加油站会员管理小程序】03 创建应用

我们上一篇介绍了数据源的创建&#xff0c;本篇我们介绍应用的创建。 微搭低代码中一共有两类应用&#xff0c;一类是数据模型应用&#xff0c;一类是自定义应用。数据模型应用往往对应着PC端的管理后台&#xff0c;例如我们的小程序通常需要一个管理后台来录入数据。 自定义…

【linux】2022年还能用,网易真的是良心啊,网易云音乐linux版本现在还是可以使用的超赞!!官方网的下载地址还可以使用,音乐使用的是qt5进行开发的。

目录前言1&#xff0c;关于网易云音乐2&#xff0c;可以正常使用&#xff0c;可以登录前言 本文的原文连接是: https://blog.csdn.net/freewebsys/article/details/128261513 未经博主允许不得转载。 博主CSDN地址是&#xff1a;https://blog.csdn.net/freewebsys 博主掘金地址…

vue.js:父子组件的实训案例

作业需求 需求1&#xff1a;定义两个输入框&#xff0c;通过输入框输输入的值改变页面显示的值需求2&#xff1a;改变第一个输入框的值的同时使得第二个输入框的值变为100倍并显示需求3&#xff1a;改变第二个输入框的值的同时使得第一个输入框的值变为1/100并显示 实训代码实…

CentOS搭建基于ZIPKIN的数据追踪系统

ZipKin入门介绍 Zipkin是一款开源的分布式实时数据追踪系统&#xff08;Distributed Tracking System&#xff09;&#xff0c;基于 Google Dapper的论文设计而来&#xff0c;由 Twitter 公司开发贡献。其主要功能是聚集来自各个异构系统的实时监控数据。分布式跟踪系统还有其…

TinUI4.0发布

引言 TinUI4登场~~~ 更新一览&#xff1a; 优化radiobox效果修复listview返回元素不全的问题新增树状图 treeview使用TinUI LOGO.ico新增普通图片 image随包发布 TinUI帮助手册 实用程序&#xff0c;在\test目录下 修复 这是常规更新&#xff0c;修复了listview创建过程中…

ChatGPT怎么用

最开始了解ChatGPT居然是抖音上看到的&#xff0c;之前了解过GPT-3&#xff0c;最开始认为可能类似的语言模型&#xff0c;上手以后才发现&#xff0c;这玩意挺有意思&#xff0c;某些方面&#xff0c;比百度强&#xff0c;但是比人还差十万八千里&#xff0c;智力不好说&#…

【Proteus仿真】【STM32单片机】智能浴室水温调控仪设计

文章目录一、功能简介二、软件设计三、实验现象联系作者一、功能简介 本项目使用Proteus8仿真STM32单片机控制器&#xff0c;使用LCD1602、DS18B20、继电器加热、电机模块等。 系统运行后&#xff0c;LCD1602显示DS18B20采集温度值、温度上限阈值。 开启加水&#xff0c;一段…