算法——暴力+优化

本质

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

例题

  • 首先容易想到的就是组合型动态规划,可是由于在求以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

相关推荐
HjhIron18 小时前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩19 小时前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹20 小时前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰1 天前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法
地平线开发者2 天前
J6B vio scenario sample
算法
BothSavage2 天前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn2 天前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法