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

python八股文算法:三数之和

双指针解法:
原理见注释

# 2025/6/6 9:40
# -*- coding:UTF-8 -*-
nums = [-1, 0, 1,1, 2, -1, -4,0,2,1,-3,4,10,-9]
def three_sum(nums):nums.sort()n = len(nums)result = []for i in range(n-2):# n-2,此时i取值到n-2-1,即倒数第3个数,此时才能保证倒数第3,倒数第2,倒数第1组成三个数的元组if i > 0 and nums[i] == nums[i-1]:continue# left right指针初始值:i+1,最后一个元素left, right = i+1, n-1while left < right:total = nums[i] + nums[left] + nums[right]# 如果和小于0,i不变,只能将left右移,因为已经排序了,往右的值会更大if total < 0:left += 1# 如果和大于0,i不变,只能将right左移,因为已经排序了,往左的值会更小elif total > 0:right -= 1# 等于0 直接加在result尾部else:result.append([nums[i], nums[left], nums[right]])# 一直到运行到此处往上,已经尝试了3个数字,需要再移动指针了,但在移动之前需要做一步去重操作,# 比如说nums=[1,2,2,3,-4]已经尝试了1,2,-4,和小于0,则需要移动left指针,即left指针下标加1,但下标加1后元素仍然是2# 所以没啥意义,需要去重,下标+1,至于移动的操作在去重完后统一加减。注意此处的+-1和while后+-1的区别while left < right and nums[left] == nums[left + 1]:left += 1while left < right and nums[right] == nums[right - 1]:right -= 1# 这里就是上述的统一加减的地方,也就是下一个循环的地方left += 1right -= 1return resultre = three_sum(nums)
print(re)

运行结果:

E:\TestData\suanfa\venv\Scripts\python.exe E:/TestData/suanfa/threesum.py
[[-9, -1, 10], [-4, 0, 4], [-4, 2, 2], [-3, -1, 4], [-3, 1, 2], [-1, -1, 2], [-1, 0, 1]]Process finished with exit code 0

相关文章:

  • GIT(AI回答)
  • JS面试常见问题——数据类型篇
  • 传输层:udp与tcp协议
  • 【递归、搜索与回溯】专题三 穷举vs暴搜vs回溯vs剪枝
  • Python获取网易云音乐的评论
  • Java-前置基础
  • Kafka 入门指南与一键部署
  • S5P6818_驱动篇(24)UART驱动
  • IoT/HCIP实验-4/单片机基础实验(LCD/LED/按键操作/GPIO/EXTI中断服务)
  • untiy 模拟人物在街道走路和跑步
  • Java中==和equals的区别
  • 理解JavaScript中map和parseInt的陷阱:一个常见的面试题解析
  • sklearn 和 pytorch tensorflow什么关系
  • 12.vite,webpack构建工具
  • 【Linux 学习计划】-- 简易版shell编写
  • 刷题记录(7)二叉树
  • 六、【ESP32开发全栈指南:深入解析ESP32 IDF中的WiFi AP模式开发】
  • 欧拉定理和费马定理
  • Gerrit+repo管理git仓库,如果本地有新分支不能执行repo sync来同步远程所有修改,会报错
  • 飞牛使用Docker部署Tailscale 内网穿透教程
  • 怎么 给自己的网站做优化呢/广州百度网站快速排名
  • 常州做网站麦策电商/在线seo推广软件
  • 如何进行一个网站建设/建立企业网站步骤
  • 网易做网站/天津做优化好的公司
  • 南宁电商网络推广/优化seo哪家好
  • 赤裸做爰游戏漫画网站/查询关键词排名工具