【算法刷题】Day9

文章目录

  • 611. 有效三角形的个数
    • 题干:
    • 题解:
    • 代码:
  • LCR 179. 查找总价格为目标值的两个商品
    • 题干:
    • 题解:
    • 代码:
  • 1137. 第 N 个泰波那契数
    • 题干:
    • 原理:
      • 1、状态表示(dp表里面的值所表示的含义)
      • 2、状态转移方程(dp[i] 等于什么)
      • 3、引初始化 (保证填表的时候不越界)
      • 4、填文顺表 (为了填写当前状态的时候,所需的状态已经计算过了)
      • 5、返回值 (题目要求 + 状态表示)
    • 代码:
    • 空间优化:

611. 有效三角形的个数

在这里插入图片描述

原题链接


题干:

首先看题干,非负整数数组,三元组数
所以,我们可知,这个数组最少有三个元素,这样才能组成三元组

在解题之前,我们补充一点:
给我们三个数,怎么判断是不是能不能构成三角形呢?
我们一般的判断都是任意两边之和大于第三边,但是如果在时间复杂度的位置上考虑,比三次太麻烦
这个时候,我们想,如果让这个数组是有序的,对比的这三个边是有序的,那么两个较短的边相加,大于第三边,是不是就可以说明前面两条边任意一条和后面的相加,都大于其余一条边呢?
在这里插入图片描述
很明显,这样是可以的,所以我们的算法就进一步进行了优化


题解:

1、暴力枚举 O(N)
暴力算法就是写三个 for 循环嵌套,在最里面的一层 for 循环判断三个数是否能组成三角形

这个算法虽然可以算出,但是由于时间复杂度太高,会导致超时

2、利用单调性,使用双指针算法解决问题
(0)排序
(1)先固定最大的数
(2)在最大的数的左区间,使用双指正,快速统计出符合要求的三元组个数
在这里插入图片描述
我们先看这个数组,我们先把最后一个数字固定,定义 left 和 right,
让left + right,如果大于 最后一个数字,那么left 右边的所有数字和 right 相加都大于,所以中间的统计下来,right –
如果小于,那么left++,再次判断
在这里插入图片描述


代码:

class Solution {public int triangleNumber(int[] nums) {//1.优化:排序Arrays.sort(nums);//2.利用双指针解决问题int ret = 0;int n = nums.length;for (int i = n - 1; i >= 2; i--) {//先固定最大的数//利用双指针快速统计处符合要求的三元组的个数int left = 0;int right = i-1;while (left < right) {if (nums[left] + nums[right] > nums[i]) {ret += right - left;right--;}else {left++;}}}return ret;}
}

在这里插入图片描述

LCR 179. 查找总价格为目标值的两个商品

在这里插入图片描述
原题链接


题干:

先看题干,升序数组,两个数相加等于 target
很好,这道题非常简单

题解:

1、暴力枚举 O(N2)
运用暴力枚举可以直接用两个 for 循环嵌套,然后再循环内部相加判断是不是和 target 相等

这个方法虽然很简单,但是时间复杂度过高,会超出时间

2、利用单调性,使用双指针解决问题
这个时候,我们依然使用我们非常熟悉的单调性和双指针
在这里插入图片描述
先判断left 和 right 相加
如果 大于 t ,right–
如果 小于 t ,left++
如果相等,直接返回


代码:

public int[] twoSum(int[] price, int target) {int left = 0;int right = price.length-1;while (left < right) {int sum = price[left] + price[right];if (sum > target) {right--;}else if (sum < target) {left++;}else {return new int[]{price[left],price[right]};}}return new int[]{0};}

在这里插入图片描述

1137. 第 N 个泰波那契数

在这里插入图片描述
原题链接


题干:

由题干可知
T0 = 0
T1 = 1
T2 = 1
Tn+3 = Tn + Tn+1 + Tn+2
可以变形为:Tn = Tn-3 + Tn-2 + Tn-1

原理:

1、状态表示(dp表里面的值所表示的含义)

由于我们在写动态规划问题的时候,需要用到dp表
dp表是怎么来的呢?

  1. 题目要求:本题 dp[i] 表示 第 i 个泰波那契数的值
  2. 经验 + 题目要求
  3. 分析问题的过程中,发现的重复子问题

2、状态转移方程(dp[i] 等于什么)

在这里插入图片描述

3、引初始化 (保证填表的时候不越界)

在这里插入图片描述

4、填文顺表 (为了填写当前状态的时候,所需的状态已经计算过了)

从左向右

5、返回值 (题目要求 + 状态表示)

dp [n]

代码:

public int tribonacci(int n) {//1.创建 dp 表//2.初始化//3.填表//4.返回值//先处理边界if(n == 0) {return 0;}if(n == 1 || n == 2) {return 1;}int[] dp = new int[n+1];dp[0] = 0;dp[1] = dp[2] = 1;for(int i = 3; i <= n; i++) {dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3];}return dp[n];}

在这里插入图片描述

空间优化:

这里我们用到的空间优化的方式是滚动数组
在解题的过程中发现,我们求 dp[i] 都是前三个数求和,不需要用到再往前的数
这个时候我们就可以拿三个数来存放,并且用后面的值改变前面的值
在这里插入图片描述
这个顺序是无法改变的,因为第二种方法,会把前面的值覆盖掉,导致出错

public int tribonacci(int n) {//空间优化//先处理边界if(n == 0) {return 0;}if(n == 1 || n == 2) {return 1;}int a = 0;int b = 1;int c = 1;int d = 0;for(int i = 3; i <= n; i++) {d = a + b + c;//滚动操作a = b;b = c;c = d;}return d;}

在这里插入图片描述

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

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

相关文章

YOLOv5改进之ShuffleNetV2

目录 一、原理 网络结构 二、代码 三、应用到YOLOv5 一、原理

Nginx(无法解析PHP网页如何解决?FPM解决你的烦恼!)

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a; 小刘主页 ♥️不能因为人生的道路坎坷,就使自己的身躯变得弯曲;不能因为生活的历程漫长,就使求索的 脚步迟缓。 ♥️学习两年总结出的运维经验&#xff0c;以及思科模拟器全套网络实验教程。专栏&#xff1a;云计算技…

Synchronized底层机制:偏向锁、轻量级锁与重量级锁及其锁升级过程

前言&#xff1a; 在Java并发编程中&#xff0c;synchronized关键字是用于实现线程同步的重要工具。在JVM中&#xff0c;synchronized的底层实现涉及到了偏向锁、轻量级锁和重量级锁这三种锁状态&#xff0c;以及锁升级过程。在之前的文章中介绍到过&#xff0c;这篇文章详细对…

LeeCode前端算法基础100题(3)- N皇后

一、问题详情&#xff1a; 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击。 给你一个整数 n &#xff0c;返回所有不同的 n 皇后…

BLP9H10-30GZ LDMOS 功率晶体管 Ampleon

BLP9H10-30GZ 30W塑料LDMOS 功率晶体管&#xff0c;适用于频率范围为616 MH 至960 MHz的基站应用。 BLP9H10-30GZ 特点和优势&#xff1a; 高效率 出色的耐用性 专为宽带操作而设计 出色的热稳定性 高功率增益 集成ESD保护 有关 RoHS 合规性 BLP9H10-30GZ应用程序&…

网易区块链,网易区块链赋能赣州脐橙数字藏品,数字指纹解决方案

目录 网易区块链 网易区块链赋能赣州脐橙数字藏品,助力革命老区三农之路 数字指纹解决方案 网易区块链 网易区块链成立于2017年,致力于Web3.0区块链技术的研发和应用。自主研发的区块链“天玄”引擎,在单链场景下支持每秒最高30万笔交易,单日可处理上链数据超10亿。 与…

智慧工地解决方案,Spring Cloud智慧工地项目平台源码

智慧工地一体化信息管理平台源码&#xff0c;微服务架构JavaSpring Cloud UniApp MySql 智慧工地云平台是专为建筑施工领域所打造的一体化信息管理平台。通过大数据、云计算、人工智能、物联网和移动互联网等高科技技术手段&#xff0c;将施工区域各系统数据汇总&#xff0c;建…

Notepad++批量添加引号

工作中经常会遇到这样情景&#xff1a;业务给到一批订单号&#xff0c;需要查询这批订单的某些字段信息。在where条件中需要传入这些订单号的数组&#xff0c;并且订单号用引号引起&#xff0c;用引号隔开。 字符串之间长度相同 可以按住CtrlAlt和鼠标左键选中区域&#xff0…

Talk | UCSB博士生许闻达:细粒度可解释评估初探

本期为TechBeat人工智能社区第551期线上Talk。 北京时间11月29日(周三)20:00&#xff0c;UC Santa Barbara博士生—许闻达的Talk将准时在TechBeat人工智能社区开播&#xff01; 他与大家分享的主题是: “细粒度可解释评估初探”&#xff0c;分享了他们团队在具备解释性的细粒度…

界面组件DevExpress Reporting v23.1新版亮点 - UX功能增强

DevExpress Reporting是.NET Framework下功能完善的报表平台&#xff0c;它附带了易于使用的Visual Studio报表设计器和丰富的报表控件集&#xff0c;包括数据透视表、图表&#xff0c;因此您可以构建无与伦比、信息清晰的报表 界面组件DevExpress Reporting v23.1已于前段时间…

python实现获取aws route53域名信息

最近由于工作原因接触到aws的服务&#xff0c;我需要实时获取所有的域名信息&#xff0c;用于对其进行扫描&#xff0c;因此写了一个自动化爬取脚本 给需要的人分享。 1.基础准备 代码环境&#xff1a;python3 第三方库&#xff1a;boto3 &#xff08;安装方法pip install…

爬虫为什么都选择python语言?爬虫使用代理IP有什么优势?

首先&#xff0c;让我们了解一下为什么爬虫都选择Python语言。 1.语言简洁易学 Python语言的设计哲学是“优雅”、“明确”、“简单”。这使得Python成为一种易于阅读和编写的语言&#xff0c;即使是初学者也可以快速上手。 2. 丰富的库和工具 Python拥有众多的第三方库和工…