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

【2025-02-06】简单算法:相向双指针 盛最多水的容器 接雨水

📝前言说明:
●本专栏主要记录本人的基础算法学习以及LeetCode刷题记录,主要跟随B站博主灵茶山的视频进行学习,专栏中的每一篇文章对应B站博主灵茶山的一个视频
●题目主要为B站视频内涉及的题目以及B站视频中提到的“课后作业”。
●文章中的理解仅为个人理解。
●文章中的截图来源于B站博主灵茶山,如有侵权请告知。

🎬个人简介:努力学习ing
📋本专栏:python刷题专栏
📋其他专栏:C语言入门基础以及python入门基础
🎀CSDN主页 愚润求学

视频

  • 一,题目汇总
  • 二,视频题目
    • 1,11.成最多水的容器
    • 2,42.接雨水

一,题目汇总

●视频题目题号:
1142

二,视频题目

1,11.成最多水的容器

●题目:
在这里插入图片描述

●题解:
找最大面积:判断什么时候会有更大面积。
如果选定了一组边,如图中的红色,则面积由短边决定,且在这组边内的任意一条边与短边的组合不糊再大于原来的面积,因为:当找到更长边时,面积还是由短边决定,但是长变短了。如果找到更短边时,长(x轴)和宽(y轴)都变短了
所以,改变短边的指针的指向别的边才可能会产生更大的面积

class Solution:def maxArea(self, height: List[int]) -> int:max = 0i, j = 0, len(height) - 1while i < j:s = (j - i ) * min(height[i], height[j])if s > max:max = sif height[i] < height[j]:i += 1else:j -= 1return max

2,42.接雨水

题目:
在这里插入图片描述
题解:
对每个长度为一的坑进行单独分析:
如果没有柱子,则一个坑能接的水取决于这个坑的前面柱子中的最大柱子和后面柱子中的最大柱子(由短的决定能接的水的数量),即某一个长为一的坑能接水的高度为max(前缀最大值,后缀最大值)
如果算上柱子,则减去柱子的柱高就是长度为一的坑的接水量
方法一:
创建两个额外的数组,用来保存每个坑的前缀和后缀的最大值,每个坑的前缀最大值为:max(上个坑的前缀最大值,该坑高度)

class Solution:def trap(self, height: List[int]) -> int:ans = 0n = len(height)pre_max = [0] * nsuf_max = [0] * n# 初始化前后缀最大值的数组pre_max[0] = height[0]for i in range(1, n):pre_max[i] = max(pre_max[i-1], height[i])suf_max[-1] = height[-1]for i in range(n-2, -1, -1):suf_max[i] = max(suf_max[i+1], height[i])for h, pre, suf in zip(height, pre_max, suf_max):ans += min(pre, suf) - hreturn ans

方法二:双向指针(明确了移动哪一边)
分析:因为每个坑能装水的高度是由min(前缀最大值,后缀最大值) - h决定的,所以,我们可以对短边进行计算,计算完后,移动短边到下一个坑
代码:

class Solution:def trap(self, height: List[int]) -> int:ans = 0n = len(height)left, right = 0, n-1pre_max = height[left]suf_max = height[right]while left <= right:pre_max = max(pre_max, height[left])suf_max = max(suf_max, height[right])if pre_max <= suf_max:ans += pre_max - height[left]left += 1else:ans += suf_max - height[right]right -= 1return ans

🌈我的分享也就到此结束啦🌈
要是我的分享也能对你的学习起到帮助,那简直是太酷啦!
若有不足,还请大家多多指正,我们一起学习交流!
📢公主,王子:点赞👍→收藏⭐→关注🔍
感谢大家的观看和支持!祝大家都能得偿所愿,天天开心!!!

http://www.lryc.cn/news/532369.html

相关文章:

  • 2.6-组合博弈入门
  • 【教学】推送docker仓库
  • 【大数据技术】本机PyCharm远程连接虚拟机Python
  • 3060显卡掉帧是为什么?3060掉帧卡顿解决方法
  • Kubernetes集群通过Filebeat收集日志
  • SQLAlchemy-2.0中模型定义和alembic的数据库迁移工具
  • [含文档+PPT+源码等]精品基于Python实现的django个性化健康餐计划订制系统
  • Python3中异常处理:try/except语句
  • [ Spring] Integrate Spring Boot Dubbo with Nacos 2025
  • 【3分钟极速部署】在本地快速部署deepseek
  • 【QT笔记】使用QScrollArea实现多行文本样式显示
  • 大模型中提到的超参数是什么
  • 【Uniapp-Vue3】z-paging插件组件实现触底和下拉加载数据
  • UE虚幻引擎No Google Play Store Key:No OBB found报错如何处理
  • OKHttp拦截器解析
  • STM32标准库移植RT-Thread nano
  • c++11总结26——std::regex
  • langchain教程-12.Agent/工具定义/Agent调用工具/Agentic RAG
  • leetcode_双指针 125.验证回文串
  • ML.NET库学习001:基于PCA的信用卡异常检查之样本处理与训练
  • 【华为OD机考】华为OD笔试真题解析(1)--AI处理器组合
  • edu小程序挖掘严重支付逻辑漏洞
  • 力扣 279. 完全平方数
  • 鸿蒙生态潮起:开发者的逐浪之旅
  • Diskgenius系统迁移之后无法使用USB启动
  • Kafka 可靠性探究—副本刨析
  • 我的博文天地测试报告
  • EtherCAT主站IGH-- 35 -- IGH之pdo_list.h/c文件解析
  • 嵌入式开发神器:Buildroot的介绍和使用方法
  • JavaScript系列(61)--边缘计算应用开发详解