算法——暴力+优化

本质

这类型题本质就是基于暴力解法,优化其时间复杂度

例题

  • 首先容易想到的就是组合型动态规划,可是由于在求以i位置为结尾的最长递增子序列的时候要遍历以[0-i-1]位置为结尾最长递增子序列的长度,所以时间复杂度会达到n^2。

  • 要求以i为结尾的最长递增子序列,实际上就是求以[0 - i-1]的元素A谁小于i位置的元素并且以其为结尾的最长递增子序列的长度L最长。对于同一L的,我们只需要保留A较小的哪个(因为同样的效果,能接在它后面肯定更容易),所以每种L的A只有一个,而L为n+1的A一定是接在了L为n的A上,因此L为n+1的A一定比L为n的A大,因此,按照L大小来排列,所有A组成有序的序列,因此我们可以通过二分查找算法(logn)找到i位置新元素最多能插入到谁后面,从而得到长度。也将时间复杂度降低到了n*logn。

  • 容易想到的就是暴力枚举第i天卖出可能得到最大利润,从中取最大值。一般思路就是每次枚举第i个位置,都要遍历[0-i-1]求一个最小值,所得的差就是最大利润。时间复杂度是n^2

  • 而我们做出的优化就是在枚举第i天卖出的途中就更新[0 - i-1]中的最小值,从而将时间复杂度降低到n

相关推荐
DFT计算杂谈19 分钟前
KPROJ编译教程
java·前端·python·算法·conda
重生之我是Java开发战士31 分钟前
【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数
java·算法·动态规划
吃好睡好便好2 小时前
用if…end…语句计算分段函数
开发语言·人工智能·学习·算法·matlab
灰灰勇闯IT2 小时前
ops-memory:CANN Runtime 的 Tensor 内存管理
算法
叶子Talk2 小时前
OpenAI破解80年数学猜想,AI首次做出原创证明
人工智能·数学·算法·机器学习·ai·openai·ai推理
MhZhou04122 小时前
1.11M参数小模型实现脑瘤分割 CVPR 2026 Findings 开源
算法·计算机视觉·3d·空间计算
有为少年3 小时前
Welford算法 | 从单一到批次
大数据·人工智能·深度学习·神经网络·算法·机器学习
吴可可1233 小时前
Teigha处理CAD样条曲线的方法解析
数据库·算法·c#
啊董dong3 小时前
noi-2026年5月12号小测验
数据结构·c++·算法
不知名的忻3 小时前
红黑树(简易版)
算法·红黑树