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

2025-2-7-算法学习(一) 动态规划-习题1 300.最长递增子序列

文章目录

  • 算法学习(一) 动态规划-习题1 300.最长递增子序列
    • (1)题目
    • (2)举例:
    • (3)提示
    • (4)分析
    • (5)动态规划代码:
    • (6)二分查找代码

算法学习(一) 动态规划-习题1 300.最长递增子序列

习题链接:
https://leetcode.cn/problems/longest-increasing-subsequence/description/

  开始快速的跟着 labuladong算法小抄 开始把算法过一遍,语言是 python3 ,正好复习一下,认认真真地系统学一遍,不再糊弄自己了,加油。

(1)题目

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。
子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

(2)举例:

输入:nums = [10,9,2,5,3,7,101,18]
输出:4
解释:最长递增子序列是 [2,3,7,101],因此长度为 4 。

(3)提示

  • 1 <= nums.length <= 2500
  • -10^4 <= nums[i] <= 10^4
  • 将算法的时间复杂度降低到 O(n log(n)) - 二分查找,动态规划复杂度为 O(n^2)

(4)分析

  • 动态规划的题目,关键是搞明白把 最优问题 转变为 最优子问题,这样就可以写出 dp 数组

(5)动态规划代码:

class Solution:def lengthOfLIS(self, nums: List[int]) -> int:# 动态规划 复杂度O(n^2)dp = [1] * len(nums)# 外层循环,控制总的dp数组长度for i in range(len(nums)):# 内层循环,控制每一位得到的最优解for j in range(i):# 当前元素大于之前的元素,进行判断比较,确定是否更新if (nums[j] < nums[i]):# 这一步的更新很有趣哦!dp[i] = max(dp[i],dp[j]+1)return max(dp)

(6)二分查找代码

class Solution:def lengthOfLIS(self, nums: List[int]) -> int:# 二分法,复杂度 O(n log n) 思路感觉和动态差别不大,但思维巧妙# 初始化 top 列表,存储每个牌堆顶部的扑克牌top = [0]*len(nums)# 牌堆数初始化为0piles = 0for poker in nums:# 二分查找左边界left,right = 0,pileswhile left < right:mid = (left+right) // 2if top[mid] < poker:left = mid + 1else:right = mid# 若没有找到合适的牌堆,新建一个牌堆if left == piles:piles += 1# 把这张牌放在对应的牌堆顶部top[left] = pokerreturn piles
http://www.lryc.cn/news/533018.html

相关文章:

  • 学习日记-250207
  • 【Block总结】PSA,金字塔挤压注意力,解决传统注意力机制在捕获多尺度特征时的局限性
  • 代码随想录算法训练营第三十一天| 回溯算法04
  • pycharm集成通义灵码应用
  • 赛博算命之 ”梅花易数“ 的 “JAVA“ 实现 ——从玄学到科学的探索
  • 【Leetcode刷题记录】54. 螺旋矩阵--模拟,以及循环条件处理的一些细节
  • c++计算机教程
  • 蓝桥杯Java之输入输出练习题
  • 【R语言】环境空间
  • 【系统架构设计师】分布式数据库透明性
  • openpnp2.2 - 环境搭建 - 编译 + 调试 + 打包
  • OpenCV:图像修复
  • QT全局所有QSS样式实时切换
  • MySQL三大版本的演进
  • 利用 IMU 估计人体关节轴向和位置 —— 论文推导
  • 脚本一键生成管理下游k8s集群的kubeconfig
  • 数据库系统概念第六版记录 三
  • YOLOv11-ultralytics-8.3.67部分代码阅读笔记-files.py
  • 微信小程序案例1——制作猫眼电影底部标签导航栏
  • 【大数据技术】搭建完全分布式高可用大数据集群(Kafka)
  • 【服务器知识】如何在linux系统上搭建一个nfs
  • 图片画质增强:轻松提升画质
  • vscode快速接入deepseek 实践操作
  • mapbox进阶,添加绘图扩展插件,绘制圆形
  • Cursor 与多语言开发:全栈开发的利器
  • 2025 CCF BDCI|“基于TPU平台的OCR模型性能优化”一等奖作品
  • FPGA的IP核接口引脚含义-快解
  • 数据库高安全—审计追踪:传统审计统一审计
  • 机器学习 - 需要了解的条件概率、高斯分布、似然函数
  • Spring Boot Web 入门