美文网首页
数组中两个元素相加等于指定数的所有组合

数组中两个元素相加等于指定数的所有组合

作者: 坤哥爱卿 | 来源:发表于2019-02-28 21:44 被阅读0次

思路1:穷举法,两层for循环

思路2:可以用hash表来存储数组中的元素,这样我们取得一个数后,去判断sum - val 在不在数组中,如果在数组中,则找到了一对二元组,它们的和为sum,该算法的缺点就是需要用到一个hash表,增加了空间复杂度。

思路3:同样是基于查找,我们可以先将数组排序,然后依次取一个数后,在数组中用二分查找,查找sum -val是否存在,如果存在,则找到了一对二元组,它们的和为sum,该方法与上面的方法相比,虽然不用实现一个hash表,也没不需要过多的空间,但是时间多了很多。排序需要O(nLogn),二分查找需要(Logn),查找n次,所以时间复杂度为O(nLogn)。

思路4:该方法基于第2种思路,但是进行了优化,在时间复杂度和空间复杂度是一种折中,但是算法的简单直观、易于理解。首先将数组排序,然后用两个指向数组的指针,一个从前往后扫描,一个从后往前扫描,记为first和last,如果 fist + last < sum 则将fist向前移动,如果fist + last > sum,则last向后移动。

相关文章

  • TwoSum

    题目大意: 找到数组中两个元素相加等于指定数的所有组合 情况一:给定数组中不含重复元素,且均为正整数 思路: 使用...

  • 数组中两个元素相加等于指定数的所有组合

    思路1:穷举法,两层for循环 思路2:可以用hash表来存储数组中的元素,这样我们取得一个数后,去判断sum -...

  • java实现 数组中两元素相加等于指定数的所有组合

    题目大意: 给一个正整数列表alist和指定正整数T,每个数只能用一次,返回两元素相加之和等于指定数的所有组合的链...

  • 7.23练习

    1.计算给定数组arr中所有元素的总和,数组中的元素均为 Number 类型 2.找出元素 item 在给定数组 ...

  • 牛客JS题目练习

    1、找出元素 item 在给定数组 arr 中的位置 2、计算给定数组 arr 中所有元素的总和 3、移除数组 a...

  • Swift-数组“运算”汇总

    两个数组“相加”——合并数组 通过运算符+,将两个数组合并到新数组。 追加元素 通过运算符+=,将右边数组追加到左...

  • Diff Two Arrays

    比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差异。

  • Diff Two Arrays - freeCodeCamp

    比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差异。 这...

  • FCC 题目 Diff Two Arrays

    题目要求 比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的...

  • Diff Two Arrays(找出两个数组的差异)for Fr

    问题: 比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差...

网友评论

      本文标题:数组中两个元素相加等于指定数的所有组合

      本文链接:https://www.haomeiwen.com/subject/dwlluqtx.html