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

德州网站制作福泉网站制作

德州网站制作,福泉网站制作,邢台住房和城乡建设部网站,源码怎样做网站文章目录 Tag题目来源解题思路方法一:最长递增子序列 写在最后 Tag 【最长递增子序列】【数组】【2023-12-22】 题目来源 1671. 得到山形数组的最少删除次数 解题思路 方法一:最长递增子序列 前后缀分解 根据前后缀思想,以 nums[i] 为山…

文章目录

  • Tag
  • 题目来源
  • 解题思路
    • 方法一:最长递增子序列
  • 写在最后

Tag

【最长递增子序列】【数组】【2023-12-22】


题目来源

1671. 得到山形数组的最少删除次数


解题思路

方法一:最长递增子序列

前后缀分解

根据前后缀思想,以 nums[i] 为山顶的山形数组可以看成 nums[i] 左侧以其作为结尾的最长递增子序列,我们记左侧的最长递增子序列的长度为 pre[i],拼接上 nums[i] 右侧以其作为结尾的最长递减子序列,我们记右侧的最长递减子序列的长度为 suf[i],此时以 nums[i] 为山顶的山形数组长度为:
p r e [ i ] + s u f [ i ] − 1 pre[i] + suf[i] - 1 pre[i]+suf[i]1
我们枚举所有的 nums[i],计算所有的最长山顶数组长度 maxLen,最后需要删除的数组元素长度为 n - maxLen 即为最后需要返回的答案。

最长递增子序列

如何计算 presuf

presuf 的计算过程类似。先来看一下 pre 的计算。维护数组 prepre[i] 表示以 nums[i] 作为结尾的最长递增子序列的长度;维护辅助数组 g,表示以当前元素 nums[i] 结尾的最长递增子序列数组。

遍历数组 nums,当前遍历的元素为 nums[i] 记为 x,在数组 g 中使用二分查找找到第一个大于 x 的元素,对应的位置为 it - g.begin() + 1

  • 更新 pre[i] = it - g.begin() + 1
  • 如果 x 不在 g 中,则将 x 加入 g;否则将 x 更新到 g 中相应的位置。

suf 的计算过程中,我们从后往前遍历数组 nums,就是找最长的递增子序列,于是计算过程和 pre 的计算类似。

remark1:因为山峰不可能在数组首和尾两个位置出现,那么在遍历所有山峰的范围 [0, n-1] 时,需要先做判断 pre[i] >= 2 && suf[i] >= 2

remark2:可以先计算 suf,然后一起计算 pre 和更新答案的,留给读者自己实现。

算法

class Solution {
public:int minimumMountainRemovals(vector<int>& nums) {int n = nums.size();vector<int> pre(n), g;for (int i = 0; i < n; ++i) {int x = nums[i];auto it = lower_bound(g.begin(), g.end(), x);pre[i] = it - g.begin() + 1;if (it == g.end()) {g.push_back(x);}else {*it = x;}}vector<int> suf(n);g.clear();for (int i = n - 1; i >= 0; --i) {int x = nums[i];auto it = lower_bound(g.begin(), g.end(), x);suf[i] = it - g.begin() + 1;if (it == g.end()) {g.push_back(x);}else {*it = x;}}int mx = 0;for (int i = 1; i < n - 1; ++i) {mx = max(mx, pre[i] + suf[i] - 1);}return n - mx;}
};

复杂度分析

时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn),更新 presuf 的时间复杂度都为 O(nlogn),更新答案的时间复杂度为 O ( n ) O(n) O(n)

空间复杂度: O ( n ) O(n) O(n),额外占用的空间为数组 presufg。空间复杂度: O ( n ) O(n) O(n),额外占用的空间为数组 presufg


写在最后

如果您发现文章有任何错误或者对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度的方法,欢迎评论区交流。

最后,感谢您的阅读,如果有所收获的话可以给我点一个 👍 哦。

http://www.yayakq.cn/news/257650/

相关文章:

  • 最好的网站建设免费的建设局网站功能简介
  • 推动品牌建设的网站网络营销的模式有哪些?
  • 门户网站ip地址段网站运营管理员具体做什么
  • 旅游网站推广方案网络建设设计方案
  • 福田网站建设龙岗网站建设罗湖网站建设罗湖网站建设建设装修网站
  • 怎么做帖子网站合肥瑶海区天气
  • 网站开发需要哪些技术人员seo软件系统
  • 在线阅读网站建设方案用网站做的简历模板
  • 综合类网站怎么做贵州黔东南双控体系建设网站
  • 网站建设公司怎么做业务网站建设制作公司
  • 建设网站困难的解决办法网站做5级分销合法吗
  • 如何制作网站教程视频讲解徐州建站费用
  • 昆明网站建设教学视频苗木网站建设
  • 自己做装修效果的网站wordpress给管理员发送邮件
  • 能在线做英语题目的网站网页设计的概念是什么
  • 专业网站建设公司兴田德润优惠吗wordpress导出导入数据库
  • 怎样做网站结构优化为什么要给企业建设网站
  • 网站首页添加浮动飘窗小程序网站开发运行合同
  • 建设网站都需要哪些内容我劝大家不要学android
  • 如何根据仿站做网站北京最大的火车站
  • 七层网络架构贵阳优化网站建设
  • 网站集约化建设 通知资阳优化团队信息
  • 企业做网站需要多少钱企业网站建设与推广
  • 淘宝客导购网站建设网站做推广赚钱项目
  • 做网站一个月能挣多少钱现在还有企业做网站的吗
  • 广西建设职业技术学院青年网站wordpress上传主题失败
  • 做漫画网站 漫画哪找163邮箱怎么申请企业邮箱
  • 北京各大网站推广服务公司做风险代理案源的网站
  • 站长工具 网站改版4399的经典小游戏
  • 网站建设的心得体会wordpress图片效果