news 2026/6/9 20:31:03

0x3f第二天复习(9:50-11:20)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
0x3f第二天复习(9:50-11:20)

1.先把昨天学习的代码敲一遍

四个题:分别记录时间

1两数之和 6min

class Solution:

def twoSum(self, nums:List[int], target:int ) -> List[int]:

nums.sort()

n = len(nums)

left = 0

right = n - 1

while left < right:

if nums[left] + nums[right] == target:

break

elif nums[left] + nums[right] < target:

left += 1

else:

right -= 1

return [left,right]

潜在问题:sort的引用想了半天也不确定,凭感觉写的num.sort()

nums[left] + nums[right]写了多遍,把他提前,加上参数,简略

错误:0x3f可以sort但是力扣这个题不行,因为力扣要返回原顺序,要用哈希表

没有考虑无解的情况,我这个代码,如果无解,还是会输出

把return放到==里面,在while之外再加一个return[]返回空列表

2.三数之和 20min

class Solution:

def threeSum(self, nums:List[int]) -> List[List[int]]:

n = len(nums)

ans = []

nums.sort()

for i in range(n-2):

target = nums[i]

#i不重复

if i>0 and target == nums[i-1]:

continue

if target + nums[i+1] + nums[i+2] > 0 :

break

if target + nums[-1] + nums[-2] < 0:

continue

j = i + 1

k = n - 1

while j < k :

s = target + nums[j] + nums[k]

if s == 0:

ans.append([target,nums[j],nums[k]])在这找到解,处理jk

return ans ×

elif s < 0:

while j<k and nums[j] == nums[j+1]:

j += 1

else:

while k<j and nums[k] == nums[k-1]:

k -= 1

j += 1

k -= 1

return []

问题:

去除jk的重复逻辑混乱,在循环的哪个地方没有弄对,应该是在找到解的循环处,进行去除

没写sort

return的位置有大问题,像这种多个解的情况,return就不能在循环里,绝对在循环的最外面,因为只要已完成return语句,直接就结束了循环

return []的意义是什么??

核心代码重敲:

if s== 0:

ans.append([target,nums[j],nums[k]])

while j<k and nums[j] == nums[j+1]:

j+=1

while k>j and nums[k] == nums[k-1]:

k-=1

j+=1 改的时候还是没写

k-=1

if s <0:

j+=1

if s>0:

k-=1

3水桶 5min

4.接水

方法一:最大前缀最大后缀数组 10min

class Solution:

def trap(self, height:List[int])->int:

#核心思想,木桶原则,只考虑短的木板,视为单个木桶,接水量为min(最大前缀,最大后缀)-底部高度

#引入数组,记录每个单位的最大前缀最大后缀

n = len(height)

ans = 0

pre_max = [0]*n

suf_max = [0]*n

pre_max[0] = height[0]

suf_max[-1] = height[-1]

#遍历得到每个最大前缀

for i in range(1,n):

pre_max[i] = max(pre_max[i],pre_max[i-1])需对比height[i]pre_max[i-1]

#遍历得到每个最大后缀

for i in range(n-2,-1,-1):

suf_max[i] = max(suf_max[i],suf_max[i+1])需对比height[i]suf_max[i+1]

for i in range(n):

ans += min(pre_max[i],suf_max[i])-height[i]

return ans

方法二:最大前缀最大后缀指针

能想到大体思路,但是最关键的点还是没想到

那就是当pre_max < suf_max的时候,不管你右边的指针指在哪,反正pre_max肯定比你小了,就可以计算pre_max,也就是当前左指针指的水桶的接水量了,也就是pre_max - height[left],然后就更新left,也就是当前left的最大前缀

另一侧同理

这就是最重要的一个思想,这就是为什么几行代码就能完成,就是靠的这个思想

核心语句:

对于右侧来说,你有可能还能变大,但我已经比你小了,对我左侧已经够了,我只需要知道premax,我就能求接水量了

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

if pre_max < suf_max:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 15:38:55

Hyrise内存数据库终极指南:下一代OLAP引擎深度解析

Hyrise内存数据库终极指南&#xff1a;下一代OLAP引擎深度解析 【免费下载链接】hyrise Hyrise is a research in-memory database. 项目地址: https://gitcode.com/gh_mirrors/hy/hyrise 在当今数据驱动的时代&#xff0c;企业面临着海量数据处理和实时分析的巨大挑战。…

作者头像 李华
网站建设 2026/6/10 15:40:00

Golang无限缓存channel

需求 最近在弄一个游戏的gate网关转发服务器&#xff0c;服务器之间使用的是nats通讯&#xff0c;gate的作用是接收客户端发来的消息转发到对应的服务器上&#xff0c;并从nats上获取游戏服务器发送给客户端的消息并转发给客户端。前面接收还好处理&#xff0c;因为都是发布订…

作者头像 李华
网站建设 2026/6/10 15:40:21

OpenVSP飞机设计终极指南:从零到精通的参数化建模完整教程

OpenVSP飞机设计终极指南&#xff1a;从零到精通的参数化建模完整教程 【免费下载链接】OpenVSP A parametric aircraft geometry tool 项目地址: https://gitcode.com/gh_mirrors/ope/OpenVSP 你是否曾经梦想设计属于自己的飞机&#xff0c;却苦于复杂的建模软件望而却…

作者头像 李华
网站建设 2026/6/10 15:40:23

ModernWMS:中小企业零成本构建专业仓储管理系统的技术实践

ModernWMS&#xff1a;中小企业零成本构建专业仓储管理系统的技术实践 【免费下载链接】ModernWMS The open source simple and complete warehouse management system is derived from our many years of experience in implementing erp projects. We stripped the original …

作者头像 李华
网站建设 2026/6/10 16:55:08

线性代数太难?5张图让你彻底搞懂矩阵分解的核心原理

线性代数太难&#xff1f;5张图让你彻底搞懂矩阵分解的核心原理 【免费下载链接】The-Art-of-Linear-Algebra Graphic notes on Gilbert Strangs "Linear Algebra for Everyone" 项目地址: https://gitcode.com/gh_mirrors/th/The-Art-of-Linear-Algebra 还在…

作者头像 李华