博客
关于我
LeetCode 15. 3Sum
阅读量:800 次
发布时间:2023-01-30

本文共 1507 字,大约阅读时间需要 5 分钟。

以下是重新优化后的内容:


题目:给定一个整数数组 S,是否存在三个元素 abc 满足 a + b + c = 0?找出所有唯一的三元组,使得它们的和为零。


题解

该问题可以看作是一个经典的 3Sum 子问题,但由于不能使用 HashMap 存储解,处理过程中需要特别注意避免重复和优化逻辑。

解题思路

  • 排序预处理:首先将数组进行排序。排序后的数组有助于减少重复计算并提高效率。
  • 双指针技巧:从数组的第一个元素开始,选择两个指针(j 和 k),分别从当前元素后面的位置和数组末尾开始遍历。
  • 和的比较
    • 如果当前三元和 nums[i] + nums[j] + nums[k] 小于目标和,将 j 指针向右移动(增加 j 的值)。
    • 如果当前三元和大于目标和,将 k 指针向左移动(减少 k 的值)。
    • 如果三元和正好等于目标值,将该三元组加入结果中。
  • 重复元素处理:在遍历时,跳过当前元素与前一个元素相等的部分,以避免重复计算相同的三元组。

  • Java 实现代码

    import java.util.ArrayList;import java.util.Arrays;import java.util.List;public class Solution {    public List
    > threeSum(int[] nums) { List
    > res = new ArrayList<>(); if (nums == null || nums.length == 0) { return res; } Arrays.sort(nums); for (int i = 0; i < nums.length - 2; i++) { if (i > 0 && nums[i] == nums[i-1]) { continue; } int j = i + 1; int k = nums.length - 1; while (j < k) { int sum = nums[i] + nums[j] + nums[k]; if (sum < 0) { j++; } else if (sum > 0) { k--; } else { res.add(Arrays.asList(nums[i], nums[j], nums[k])); j++; k--; } } } return res; }}

    返回版本说明

  • 代码结构:遵循标准的三元排序方法,通过双指针技巧在预排序数组中找到所有满足条件的三元组。
  • 避免重复:在遍历过程中,跳过重复的元素,确保每个三元组只被记录一次。
  • 高效性:采用排序策略和双指针法,时效复杂度为 O(n²),在大多数情况下表现良好。

  • 转载地址:http://uagyk.baihongyu.com/

    你可能感兴趣的文章
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>