九章算法面试题66 2 sum

九章算法官网-原文网址

http://www.jiuzhang.com/problem/67/

题目

给一堆数组和一个目标值,在这堆数组里面找出两个数使得他们的和等于目标值。

在线测试本题

http://www.lintcode.com/en/problem/2-sum/

解答

如果原题的数组中第i个元素我们用ai来表示,目标值我们用v来表示。

这道题有两种方法可以解:

方法一:

既然是需要找两个数使得他们的和为目标值, 一说到查找我们就会想到hash,因为hash可以帮助我们加快查找方法。 然后我们可以for循环扫一遍我们的数组,并且hash表存储在扫到第i个数时候,前面扫过的i-1个数。 这样我们找的其实是前面有没有一个元素和第i个数ai 相加为v , 那么我们只用在hash表里面去查找有没有v-ai这个元素如果有,那么就说明前面i-1个数中有一个数加上ai
他们的和为v. 这种方法的时间复杂度是O(n),空间复杂度是O(n)。

方法二:

这种方法叫做两个指针,我们可以先把数组排序,然后两个指针分别指向数组一头一尾数组最大和最小的元素,我们把这两个指针叫做front和end。 如果a[front] + a[end] > v, 那么说明front右边所有的元素+end的值都会大于v,所以我们不需要考虑这些元素了。所以只用把end-1,也就是end指针向有数组左边移动。 如果a[front] + a[end] < v,那么说明end左边所有的元素+end的值也都会小于v,所以我们也不用考虑这些元素了。所以只用把front+1,也就是front指针向数组右边移动。
这样一直循环到front指针=end指针停止。用这种方法我们就可以找到两个指针使得他们的和等于v。 这种方法的时间复杂度是O(nlogn+n) , 空间复杂度是O(1).

时间: 2024-07-30 03:55:20

九章算法面试题66 2 sum的相关文章

九章算法面试题67 3 sum

九章算法官网-原文网址 http://www.jiuzhang.com/problem/68/ 题目 给一堆数组和一个目标值,在这堆数组里面找出三个数使得他们的和等于目标值. 在线测试本题 http://www.lintcode.com/en/problem/3-sum/ 解答 如果原题的数组中第i个元素我们用ai来表示,目标值我们用v来表示. 这道题的方法非常类似2 sum的第二种解法.首先我们还是先把数组排一个顺序, 然后我们现在还是需要三个指针i,j,k, 我们假设i<j<k,因为我们排

九章算法面试题68 4 sum

九章算法官网-原文网址 http://www.jiuzhang.com/problem/69/ 题目 给一堆数组和一个目标值,在这堆数组里面找出四个数使得他们的和等于目标值. 在线测试本题 http://www.lintcode.com/en/problem/4-sum/ 解答 方法一: 这道题的方法也非常类似2 sum的第二种解法.首先我们还是先把数组排一个顺序, 然后我们现在还是需要四个指针i,j,x,y, 我们假设i<j<x<y,因为我们排了序,那么a[i]<a[j]<

九章算法面试题31 子数组的最大差

九章算法官网-原文网址 http://www.jiuzhang.com/problem/31/ 题目 给定一个数组,求两个不相交的并且是连续的子数组A和B(位置连续),满足|sum(A) - sum(B)|最大(和之差的绝对值).例如[2, -1, -2, 1, -4, 2, 8],可以得到A=[-1, -2, 1, -4], B=[2, 8],最大差为16. 解答 预处理每个位置往左/右的最大/最小子数组,然后再枚举划分位置,求得所有MaxLeft[i] - MinRight[i+1]和Max

九章算法面试题43 直方图内最大矩阵

九章算法官网-原文网址 http://www.jiuzhang.com/problem/43/ 题目 给出一个直方图(如图所示),求出所给直方图中所包含的最大矩阵面积.直方图可以用一个整数数组表示,如上图为[2, 1, 5, 6, 2, 3].每个直方块的宽度均为1.上图中包含的最大矩阵面积为10. 解答 如果对于每个直方块,找到从它开始往左边数第一个比它小的,和往右边数第一个比他小的,则可以确定出以该直方块为最矮一块的矩阵的最大面积.使用数据结构栈,栈中保存递增序列,从左到右依次遍历每个数让其

九章算法面试题37 主元素

九章算法官网-原文网址 http://www.jiuzhang.com/problem/37/ 题目 主元素(Majority Number)定义为数组中出现次数严格超过一半的数.找到这个数.要求使用O(1)的额外空间和O(n)的时间. 进阶1:如果数组中存在且只存在一个出现次数严格超过1/3的数,找到这个数.要求使用O(1)的额外空间和O(n)的时间. 进阶2:如果数组中存在且只存在一个出现次数严格超过1/k的数,找到这个数.要求使用O(k)的额外空间和O(n)的时间 解答 采用抵消法.一旦发

九章算法面试题40 不用除法求积

九章算法官网-原文网址 http://www.jiuzhang.com/problem/40/ 题目 给定一个数组A[1..n],求数组B[1..n],使得B[i] = A[1] * A[2] .. * A[i-1] * A[i+1] .. * A[n].要求不要使用除法,且在O(n)的时间内完成,使用O(1)的额外空间(不包含B数组所占空间). 解答 计算前缀乘积Prefix[i] = A[1] * A[2] .. A[i],计算后缀乘积Suffix[i] = A[i] * A[i+1] ..

九章算法面试题50 队列上实现Min函数

九章算法官网-原文网址 http://www.jiuzhang.com/problem/50/ 题目 ?在<九章算法面试题23 栈上实现Min函数>中,我们介绍了在栈上实现一个O(1)的Min方法.那么,如何在队列上实现一个Min方法? 要求,队列除了支持基本的Push(x) Pop()的方法以外,还需要支持Min方法,返回当前队列中的最小元素.每个方法的均摊复杂度为O(1) 解答 在九章面试题49<用栈实现队列>和面试题23<栈上实现Min函数>中,我们讲解到了如何用

九章算法面试题42 构造MaxTree

九章算法官网-原文网址 http://www.jiuzhang.com/problem/42/ 题目 给定一个没有重复元素的数组A,定义A上的MaxTree如下:MaxTree的根节点为A中最大的数,根节点的左子树为数组中最大数左边部分的MaxTree,右子树为数组中最大数右边部分的MaxTree.请根据给定的数组A,设计一个算法构造这个数组的MaxTree. 解答 如果能够确定每个节点的父亲节点,则可以构造出整棵树.找出每个数往左数第一个比他大的数和往右数第一个比他大的数,两者中较小的数即为该

九章算法面试题29 子矩阵的最大公约数

九章算法官网-原文网址 http://www.jiuzhang.com/problem/29/ 题目 给定n*n的矩阵,需要查询任意子矩阵中所有数字的最大公约数.请给出一种设计思路,对矩阵进行预处理,加速查询.额外的空间复杂度要求O(n^2)以内. 解答 构建二维线段树.预处理时间O(n^2),每次查询O(log n) 面试官角度 这个题目需要具备一定的数据结构功底.线段树(Interval Tree)可以解决的问题是那些满足结合律的运算.最大公约数是一个满足结合律的运算.所以有,GCD(A,B