• 文心一言 Python编程之


    给一个包含n个整数的数组nums,判断nums中是否存在三个元素a,b,c,使得a+b+c=0?请你找出所有和为0且不重复的三元组。 注意:答案中不可以包含重复的三元组。

    示例1: 输入:nums=[-1,0,1,2,-1,-4] 输出:[[-1,-1,2],[-1,0,1]]

    示例2: 输入:nums = [] 输出:[]

    示例3: 输入:nums = [0] 输出:[]

    文心一言编程如下(自带注释)

    1. def three_sum(nums):
    2. if len(nums) < 3:
    3. return []
    4. nums.sort() # 对数组进行排序
    5. result = []
    6. # 遍历数组,固定第一个元素
    7. for i in range(len(nums) - 2):
    8. # 避免重复的三元组
    9. if i > 0 and nums[i] == nums[i - 1]:
    10. continue
    11. # 双指针法,在剩余部分寻找和为-nums[i]的两个数
    12. left = i + 1
    13. right = len(nums) - 1
    14. while left < right:
    15. total = nums[i] + nums[left] + nums[right]
    16. if total < 0:
    17. # 和太小,移动左指针
    18. left += 1
    19. # 避免重复的三元组
    20. while left < right and nums[left] == nums[left - 1]:
    21. left += 1
    22. elif total > 0:
    23. # 和太大,移动右指针
    24. right -= 1
    25. # 避免重复的三元组
    26. while left < right and nums[right] == nums[right + 1]:
    27. right -= 1
    28. else:
    29. # 找到和为0的三元组
    30. result.append([nums[i], nums[left], nums[right]])
    31. left += 1
    32. right -= 1
    33. # 避免重复的三元组
    34. while left < right and nums[left] == nums[left - 1]:
    35. left += 1
    36. while left < right and nums[right] == nums[right + 1]:
    37. right -= 1
    38. return result
    39. # 示例1
    40. nums1 = [-1, 0, 1, 2, -1, -4]
    41. print(three_sum(nums1))
    42. # 示例2
    43. nums2 = []
    44. print(three_sum(nums2))
    45. # 示例3
    46. nums3 = [0]
    47. print(three_sum(nums3))

  • 相关阅读:
    反素数
    拿捏指针(一)
    flutter 加.then方法
    python中的装饰器(基础装饰器)
    Apache DolphinScheduler新一代分布式工作流任务调度平台实战
    STM32HAL库CRC学习及测试记录
    OpenCV显示10bit Raw数据
    1057 Stack
    从零开始学习调用百度地图网页API:一、注册百度地图账号
    【期权系列】顶部和底部信号:期权看跌看涨比(PCR)
  • 原文地址:https://blog.csdn.net/2202_75561400/article/details/136407848