博客
关于我
刷题37-数组中和为0的三元组
阅读量:704 次
发布时间:2019-03-21

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

首先,让我们分析一下这个问题:给定一个整数数组S,需要找到所有满足a + b + c = 0并按非降序排列的三元组(a, b, c)。为了高效解决这个问题,我们可以采用以下优化算法:

  • 排序数组:对数组进行升序排序,这样可以简化后续的查找过程。排序后的数组有助于跳过重复的元素,并且能够快速定位到所需的元素。

  • 双重循环结构:使用外层循环和内层循环来遍历所有可能的三元组。外层循环控制第一个元素i,内层循环控制第二个元素j。这种方法将原本的三重循环减少到仅双重循环,显著降低了时间复杂度。

  • 跳过重复元素:在循环过程中,跳过那些与前一个相同的元素,避免生成重复的三元组。例如,如果当前元素等于前一个元素,那么外层循环中的i不会移动,直到遇到下一个不同的元素。

  • 二分查找法:对于每一个双(i, j),计算目标值target = -(nums[i] + nums[j]),然后使用二分查找来查找target是否存在于数组中,并且确保它的位置在j之后。这种方法有助于在O(log n)的时间内定位元素,进一步优化了查找过程。

  • 以下是详细的实现步骤:

    • 对数组进行排序。
    • 初始化一个空的结果列表storeResults。
    • 外层循环遍历数组中的每个元素i。
      • 内层循环遍历数组中的每个元素j,确保j > i。
      • 跳过那些与前一个相同的元素j,避免重复处理。
      • 计算target = -(nums[i] + nums[j])。
      • 使用二分查找在数组中查找target,确保它的位置在j之后。
      • 如果找到target,生成三元组并将其添加到结果列表中,确保三元组按非降序排列。

    通过这种方法,我们可以有效地找到所有满足条件的三元组,并且避免了重复处理。这种方法的时间复杂度为O(n² log n),在处理长度为10^4的数组时具有一定的效果。不过,为了进一步优化,可以考虑使用更高级的算法或数据结构,比如使用哈希集合来快速检验是否存在满足条件的第三个元素。

    在代码实现时,需要注意以下几点:

    • 排序:确保数组是升序排列,这样可以在后续步骤中方便地跳过重复元素。
    • 跳过重复元素:在双重循环中,跳过那些与前一个相同的元素,避免生成重复的三元组。
    • 二分查找:使用正确的二分查找方法,确保在数组中找到正确的目标值,并且目标值的位置在j之后。
    • 生成结果:生成每个符合条件的三元组时,确保它们按照非降序排列,并在结果列表中添加独特的三元组。

    这个方法不仅能够高效地解决问题,还可以通过减少重复计算和跳过不必要的循环,提升整体代码的性能。对于更复杂的数组,或者需要处理大量数据的情况,可能需要进一步优化,比如使用分治策略或其他高级算法。

    最终,我们可以编写如下的Java代码来实现这个算法:

    import java.util.ArrayList;import java.util.Arrays;import java.util.List;public class Solution {    public List
    > threeSum(int[] num) { List
    > res = new ArrayList<>(); if (num.length < 3) { return res; } Arrays.sort(num); List
    prev = new ArrayList<>(); for (int i = 0; i < num.length; i++) { if (i > 0 && num[i] == num[i - 1]) { continue; } List
    current = new ArrayList<>(); current.add(num[i]); prev.add(current.get(0)); for (int j = i + 1; j < num.length; j++) { if (j > i + 1 && num[j] == num[j - 1]) { continue; } int target = -(num[i] + num[j]); int index = Arrays.binarySearch(num, j + 1, num.length, target); if (index >= 0) { List
    triplet = new ArrayList<>(); triplet.add(num[i]); triplet.add(num[j]); triplet.add(num[index]); if (!isDuplicate(res, triplet)) { res.add(triplet); } } } } return res; } private boolean isDuplicate(List
    > res, List
    triplet) { for (List
    list : res) { if (list.equals(triplet)) { return true; } } return false; }}

    这个代码首先对输入数组进行排序,然后使用双重循环遍历所有可能的三元组。通过跳过相同的元素和使用二分查找,有效地减少了重复计算,并确保每个三元组都是唯一的。isDuplicate方法用于检查结果列表中是否已经存在该三元组,以防止重复添加。这种方法保证了结果的准确性和唯一性。

    转载地址:http://tjtez.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>