每日一练 1(双指针)(单调性)

1.题目解析

2.解题

2.1暴力解法(遍历)

用for循环穷举所有组合的容积,找出最大值

测试用例可通过,但是提交不会过,这是一道中等题,对时间复杂度会有要求,这里的时间复杂度为O(N*2),提交就会显示超时。

2.2更优解

思路

首先本题是第一道求最值问题,我们可以尝试找出体积增长的规律(单调性)来运用双指针来解题。

就本题给出的示例:

a.给出双指针,准备遍历:

b.计算容积

c.观察遍历规律:(这里"指针"就代表指向元素)

d.得出结论:

前一次体积计算完之后,无需将较小的一方与剩下的元素进行遍历,而是直接舍去较小值与其他元素组合的情况,大大减少计算量,只需要遍历一次即可。

写代码

建议大家了解算法原理之后自己上手敲一遍代码再看答案

相关推荐
myloveasuka5 分钟前
红黑树、红黑规则、添加节点处理方案
开发语言·算法
沉鱼.446 分钟前
枚举问题集
java·数据结构·算法
2301_810160956 分钟前
C++中的访问者模式高级应用
开发语言·c++·算法
郝学胜-神的一滴7 分钟前
走进计算机图形学的浪漫宇宙 | GAMES101 开篇课程全解析
c++·算法·图形渲染·计算机图形学
没头脑的男大8 分钟前
灵神,2x树的层序遍历,102,103,513
算法
m0_518019489 分钟前
C++中的享元模式
开发语言·c++·算法
我带你来这儿就是为了告诉你我14 分钟前
C++23新特性前瞻
开发语言·c++·算法
陌夏18 分钟前
快速排序 (Quick Sort)
算法
IronMurphy28 分钟前
【算法二十九】 437. 路径总和 III
算法·深度优先
2501_9083298529 分钟前
C++安全编程指南
开发语言·c++·算法