数组两两求和值为key


数组中的数两两求和,和为key的个数,且数组中的数只能用一次

下面是js实现:

<script>
function addSum(arr,key){
var num = 0;
var newarr = [];
for(var i=0;i<arr.length;i++){
for(var j=0;j<arr.length;j++){
if(arr[i] + arr[j] == key && i!=j && newarr.indexOf(arr[i])==-1 && newarr.indexOf(arr[j])==-1){
num++;
newarr.push(arr[i]);
newarr.puslocalStorage 与 sessionStorageh(arr[j]);
}
}
}
return num;
}
alert(add([1,2,3,4,5],6));
</script>

下面是python实现:

利用 哈希表,把元素值设为key,对应下标为value 
 遍历数组,当前数为ai,如果哈希表里有target-ai的键,结果就出来了 
class Solution(object):
    # @return a tuple, (index1, index2)
    def twoSum(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[int]
        """
        dic = {}
        size = len(nums)
        for i in range(size):
            dic[nums[i]] = i
        for i in range(size):
            if dic.get(target-nums[i]):
                return i+1,dic.get(target-nums[i])+1


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值