代码随想录第十七天|动态规划(1)

目录

LeetCode 509. 斐波那契数列

LeetCode 70. 爬楼梯

LeetCode 746. 使用最小花费爬楼梯

LeetCode 62. 不同路径

LeetCode 63. 不同路径 II

总结


动态规划在算法课上学习过,看过了之后有一些熟悉感。(虽然贪心算法也学过,但是不如动态规划这样有统一的想法。)

对于动态规划问题,可以拆解为以下五步:

  1. 确定dp数组以及下标的含义
  2. 确定递推公式
  3. dp数组如何进行初始化
  4. 确定dp数组的遍历顺序
  5. 举例推导dp数组

在写题解的时候,基本上就按照这五步来写

LeetCode 509. 斐波那契数列

题目链接:LeetCode 509. 斐波那契数列

思想:本题的dp数组很明显,就是斐波那契数列;递推公式就是dp[i] = dp[i-1]+dp[i-2];初始化也很简单,dp[0]=0,dp[1]=1;遍历顺序的话就是从第二项遍历到第n项,如果n<2的话,就可以直接return n;同时,因为一次的遍历只涉及三个数,且只需要返回第n项的斐波那契值。所以dp数组的大小可以只设置为2。

代码如下:

    int fib(int n) {if (n <= 1) return n;int dp[2];dp[0] = 0;dp[1] = 1;for (int i = 2; i <= n; i++) {int sum = dp[0] + dp[1];dp[0] = dp[1];dp[1] = sum;}return dp[1];}

时间复杂度:O(n),空间复杂度:O(1)。

LeetCode 70. 爬楼梯

题目链接:LeetCode 70. 爬楼梯

思想:本题其实与斐波那契数列十分相似,到达i层的话有dp[i]种方法,而到达i层可以通过i-1层爬一楼,通过i-2层爬两楼,所以本题的递推公式就是dp[i]=dp[i-1]+dp[i-2]。dp数组的话就是到达每一层楼有多少种方法,初始化就是到达第一层有一种,到达第二层有两种方法,即dp[0]=1,dp[1]=2;遍历就是从第三层到第n层了。

代码如下:

    int climbStairs(int n) {if (n == 1) return n;int dp[2];dp[0] = 1;dp[1] = 2;int flood = 2;while (flood++ != n) {int sum = dp[0] + dp[1];dp[0] = dp[1];dp[1] = sum;}return dp[1];}

时间复杂度:O(n),空间复杂度:O(1)。

LeetCode 746. 使用最小花费爬楼梯

题目链接:LeetCode 746. 使用最小花费爬楼梯

思想:本题的dp数组应该是到达该阶梯需要支付的最小费用,下标就是台阶;递推公式的话,应该是到这一层所需要支付的最小费用,到第i层的话,需要在第i-1爬一楼或者在第i-2爬两楼,最小费用的就取这两个的最小值并且要加上本身;dp数组的初始化就是应该等于cost;遍历也是从dp的第三项开始;在调试的时候,发现结果数组会把最后一项的数加上,这是因为题目中的楼顶是数组尺寸+1,所以应该要往dp数组里面再加一个元素,加0就行了。

代码如下:

    int minCostClimbingStairs(vector<int>& cost) {vector<int> dp = cost;dp.push_back(0);for (int i = 2; i < dp.size(); i++) {dp[i] += min(dp[i - 1], dp[i - 2]); }return dp[dp.size() - 1];}

时间复杂度:O(n),空间复杂度:O(n)。

LeetCode 62. 不同路径

题目链接:LeetCode 62. 不同路径

思想:本题十分熟悉,是动态规划的经典题,看了一眼就想起来了。dp数组就是表示到当前这个格子可以通过多少条路;一个格子只能由它的左边或者上边达到,所以dp[i][j]=dp[i-1][j]+dp[i][j-1];关于dp的初始化,对于棋盘边上的数组即左上角往右走的一条路和左上角往下走的一条路,其值都应该等于1;最后遍历就遍历整个dp数组就行了。

代码如下:

    int uniquePaths(int m, int n) {vector<vector<int>> dp(m, vector<int>(n, 0));for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (j - 1 < 0 || i - 1 < 0) {dp[i][j] = 1;} else {dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}}return dp[m - 1][n - 1];}

时间复杂度:O(n^2),空间复杂度:O(n^2)。

LeetCode 63. 不同路径 II

题目链接:LeetCode 63. 不同路径 II

思想:本题对于上题基本上是一模一样的,但是有一个特别不同,就是初始化。上一题的初始化是沿着边框线全部初始化为1,但本题不一样,如果在边框线上有障碍物的话,障碍物以及障碍物以后的dp数组应该全为0。

代码如下:

    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {if (obstacleGrid[0][0] == 1) return 0;int m = obstacleGrid.size();int n = obstacleGrid[0].size();vector<vector<int>> dp(m, vector<int>(n, 0));for (int i = 0; i < m && obstacleGrid[i][0] == 0; i++) dp[i][0] = 1;for (int j = 0; j < n && obstacleGrid[0][j] == 0; j++) dp[0][j] = 1;for (int i = 1; i < m; i++) {for (int j = 1; j < n; j++) {if (obstacleGrid[i][j] == 1) {continue;}dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}return dp[m - 1][n - 1];}

时间复杂度:O(n^2),空间复杂度:O(n^2)。

总结

刷到动态规划的话,也算是到了熟悉的领域了。贪心算法有些实在是想不出来。

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

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

相关文章

样式迁移及代码

一、定义 1、使用卷积神经网络&#xff0c;自动将一个图像中的风格应用在另一图像之上&#xff0c;即风格迁移&#xff1b;两张输入图像&#xff1a;一张是内容图像&#xff0c;另一张是风格图像。 2、训练一些样本使得样本在一些cnn的特征上跟样式图片很相近&#xff0c;在一…

Java字符串与Unicode编码(码点、代码单元、基本多语言平面BMP、辅助平面、代理对)

Java字符串与Unicode编码 1. Unicode编码简介 Unicode是一个为世界上所有书写系统设计的字符编码标准。它旨在解决不同编码标准之间不兼容的问题&#xff0c;使得计算机能够处理和显示世界上几乎所有的字符。Unicode为每个字符分配了一个唯一的数字&#xff0c;称为“码点”&…

字典集合案例

1.统计字符 统计字符串中每个字符出现的次数 s l like summer very much #去掉空格 s s.replace(" ","") d dict() for i in s:if i in d:d[i] 1else:d[i] 1 for i in d:print(i,d[i]) 2.求不重复的随机数 #导入随机数 import random a int(input(&q…

自动化测试的艺术:Xcode中GUI测试的全面指南

自动化测试的艺术&#xff1a;Xcode中GUI测试的全面指南 在软件开发过程中&#xff0c;图形用户界面&#xff08;GUI&#xff09;测试是确保应用质量和用户体验的关键环节。Xcode&#xff0c;作为苹果的官方集成开发环境&#xff08;IDE&#xff09;&#xff0c;提供了一套强大…

智能疲劳驾驶检测:基于YOLO和深度学习的全流程实现

引言 疲劳驾驶是导致交通事故的重要原因之一。为了提高道路安全&#xff0c;及时检测和预警驾驶员的疲劳状态显得尤为重要。本文介绍了一种基于深度学习的疲劳驾驶检测系统。该系统利用YOLO模型&#xff08;YOLOv8/v7/v6/v5&#xff09;进行疲劳驾驶检测&#xff0c;并提供了详…

OD C卷 - 密码输入检测

密码输入检测 &#xff08;100&#xff09; 给定一个密码&#xff0c;‘<’ 表示删除前一个字符&#xff0c;输出最终得到的密码&#xff0c;并判断是否满足密码安全要求&#xff1a; 密码长度>8;至少包含一个大写字母&#xff1b;至少包含一个小写字母&#xff1b;至少…

探索若依(Ruoyi):开源的企业级后台管理系统解决方案

探索若依&#xff08;Ruoyi&#xff09;&#xff1a;开源的企业级后台管理系统解决方案 在现代企业管理中&#xff0c;拥有一个高效、稳定的后台管理系统是至关重要的。若依&#xff08;Ruoyi&#xff09;作为一款开源的企业级后台管理系统&#xff0c;为企业提供了丰富的功能…

SpringBoot中JSR303校验

JSR是 Java EE 的一种标准&#xff0c;用于基于注解的对象数据验证。在Spring Boot应用中&#xff0c;你可以通过添加注解直接在POJO类中声明验证规则。这样可以确保在使用这些对象进行操作之前&#xff0c;它们满足业务规则。个人认为非常有用的&#xff0c;因为它减少了代码中…

2.6基本算法之动态规划2989:糖果

描述 由于在维护世界和平的事务中做出巨大贡献&#xff0c;Dzx被赠予糖果公司2010年5月23日当天无限量糖果免费优惠券。在这一天&#xff0c;Dzx可以从糖果公司的N件产品中任意选择若干件带回家享用。糖果公司的N件产品每件都包含数量不同的糖果。Dzx希望他选择的产品包含的糖…

被问到MQ消息已丢失,该如何处理?

在分布式系统中&#xff0c;消息中间件&#xff08;如 RabbitMQ、RocketMQ、Kafka、Pulsar 等&#xff09;扮演着关键角色&#xff0c;用于解耦生产者和消费者&#xff0c;并确保数据传输的可靠性和顺序性。尽管我们通常会采取多种措施来防止消息丢失&#xff0c;如消息持久化、…

【Vue实战教程】之 Vue Router 路由详解

Vue Router路由 1 路由基础 1.1 什么是路由 用Vue.js创建的项目是单页面应用&#xff0c;如果想要在项目中模拟出来类似于页面跳转的效果&#xff0c;就要使用路由。其实&#xff0c;我们不能只从字面的意思来理解路由&#xff0c;从字面上来看&#xff0c;很容易把路由联想…

HTML(五)——HTML区块,布局

HTML区块 HTML可以通过 <div> 和 <span>将元素组合起来&#xff0c;可以来布局&#xff0c;就是盒子&#xff0c;div是块级盒子&#xff0c;里面 可以放任何东西&#xff0c;span里面装的是文本 HTML 区块元素 大多数 HTML 元素被定义为块级元素或内联元素。 实…

Java 面试 | Redis

目录 1. 在项目中缓存是如何使用的&#xff1f;2. 为啥在项目中要用缓存&#xff1f;3. 缓存如果使用不当会造成什么后果&#xff1f;4. redis 和 memcached 有什么区别&#xff1f;5. redis 的线程模型是什么&#xff1f;6. 为什么单线程的 redis 比多线程的 memcached 效率要…

dns逆向解析,主从服务,多域名访问(穿插ntp服务器)

复习 域名解析&#xff1a; 正向解析&#xff1a;将域名解析为ip 反向解析&#xff1a;将ip解析为域名 逆向解析 关闭防火墙和selinux&#xff0c;配置静态ip [rootdns ~]# vim /etc/named.rfc1912.zones [rootdns ~]# vim /etc/named.conf [rootdns ~]# cd /var/named/ [rootd…

【电子数据取证】了解数据库

文章关键词&#xff1a;电子数据取证、数据库取证、手机取证 一、前言 数据库是信息系统中不可或缺的部分。无论是取证收集&#xff0c;网站重建又或是开发程序都离不开数据库这个角色。 可能你已经或多或少看到过像是MySQL、Redis、MongoDB之类的程序&#xff0c;这些程序统…

前端:Vue学习-4

前端&#xff1a;Vue学习-4 1. 组件缓存 keep-alive2. 状态管理工具 - Vuex2.1 vuex 提供数据&使用数据 - mapState2.2 mutations 修改数据 - mapMutations2.3 actions - 异步操作 - mapActions2.4 getters - 计算属性 - mapGetters 3. Vuex 模块 modules - state,mutation…

day07:用户下单、订单支付

文章目录 地址薄相关相关代码需求分析和设计代码书写 用户下单需求分析和设计代码开发 订单支付微信支付介绍微信支付准备工作如何保证数据安全&#xff1f;如何调用到商户系统 地址薄相关相关代码 需求分析和设计 产品原型接口设计数据库设计 代码书写 地址薄相关代码都是单…

Objects类

Objects类 Objects类&#xff1a;常用方法&#xff1a;equals()&#xff1a; Objects类&#xff1a; Objects是一个工具类&#xff0c;提供了很多操作对象的静态方法给我们使用。 常用方法&#xff1a; 方法名说明public static boolean equals(Object a, Object b)先做非空判…

电商大型活动行动清单样例

背景 为保证在大型活动/节日&#xff08;双十一、黑色星期五&#xff09;时服务稳定&#xff0c;提出各个角色必要的行动清单 涉及到的角色与职能范围&#xff08;包括但不限于&#xff09; 产品&#xff1a;确定核心功能链路&#xff0c;制定服务降级默认行为&#xff0c;提…

视频行业(监控,直播,会议,视频通话)痛点,随时接入,异构融合,以OvMeet视频会议为中心解决企业视频应用完美解决方案

近年来随着网络的普及及音视频技术的不断发展&#xff0c;以全球化、网络化、智能化未趋势的办公方式越来越受到各行各业的青睐。视频会议解决方案的应用转往多种交互式视频应用&#xff0c;如转往视频接入融合&#xff0c;调度与管理、日常沟通、工作部署、紧急救援、作战指挥…