猿创征文 |【算法面试入门必刷】动态规划-线性dp(四)

2024-03-04 1389阅读

温馨提示:这篇文章已超过385天没有更新,请注意相关的内容是否还可用!

【算法面试入门必刷】动态规划-线性dp(四)

  • 前言
  • 算法入门刷题训练
    • 题目AB37:最长上升子序列(一)
      • 题目分析
      • 理论准备
      • 题解
      • 小结

        📦个人主页:一二三o-0-O的博客

        🏆技术方向:C/C++客户端资深工程师(直播+音视频剪辑)

        👨‍💻作者简介:数据结构算法与音视频领域创作者

        📒 系列专栏:牛客网面试必刷

        📣专栏目标:帮助伙伴们通过系统训练,掌握数据结构与算法,收获心仪Offer

        📝推荐一个找工作神器:牛客刷题网 【面试经验|实习招聘内推,求职就业一战解决】

        🧡如果对您有帮助的话,欢迎点赞👍收藏📂,关注不迷路

        【算法入门必刷】数据结构-栈篇系列文章:

        【算法入门必刷】数据结构-栈(一)

        【算法入门必刷】数据结构-栈(二)

        【算法入门必刷】数据结构-栈(三)

        【算法入门必刷】数据结构-栈(四)

        【算法入门必刷】数据结构-栈(五)

        【算法入门必刷】动态规划-线性dp篇系列文章:

        【算法面试入门必刷】动态规划-线性dp(一)

        【算法面试入门必刷】动态规划-线性dp(二)

        【算法面试入门必刷】动态规划-线性dp(三)

        前言

        开启刷题,请点击右边链接进行跳转点击这里

        猿创征文 |【算法面试入门必刷】动态规划-线性dp(四)

        算法入门刷题训练

        题目AB37:最长上升子序列(一)

        题目分析

        描述

        给定一个长度为 n 的数组 arr,求它的最长严格上升子序列的长度。

        所谓子序列,指一个数组删掉一些数(也可以不删)之后,形成的新数组。例如 [1,5,3,7,3] 数组,其子序列有:[1,3,3]、[7] 等。但 [1,6]、[1,3,5] 则不是它的子序列。

        我们定义一个序列是 严格上升 的,当且仅当该序列不存在两个下标 i 和 j 满足 i}; // 求得从下标0到下标i-1中dp值的最大值 for(int j{};j // 当当前值大于v[j],才进行dp[j]的判断 if(v[i] v[j]){ maxValue = max(maxValue,dp[j]); } } // 然后dp[i]就等于之前的最大的连续子序列的长度加上当前数值 dp[i] = maxValue + 1; 1};i int maxValue{}; // 内部从小到大,从大到小都可以 for(int j{};j if(v[i] v[j]){ maxValue = max(maxValue,dp[j]); } } } int n; cin n; vector v(n); for(int i{};i> v[i]; // dp[i] 表示以第i个数字为结尾的最长连续子序列的长度 vector dp(n,1); int result{}; for(int i{1};i int maxValue{}; for(int j{};j if(v[i] v[j]){ maxValue = max(maxValue,dp[j]); } } dp[i] = maxValue + 1; if(dp[i] result) result = dp[i]; } cout

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]