每天算法 -- 两数和 - easy

这篇博客探讨了如何在数组中寻找两个数,使它们的和等于给定的目标值k。文章提供了四种解决方案:暴力法、排序加二分查找、排序加前后逼近以及使用哈希表的方法。暴力法通过遍历数组并比较每个元素与k的差值来查找,而排序法结合二分查找或前后指针可以降低时间复杂度。哈希表的方法则能实现线性时间复杂度的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

Solution 1 暴力法:

Solution 2, 排序 + 二分查找

Solution 3 排序 + 前后逼近

Solution 4 Hash表


Google:

Given a list of numbers and a number k, return whether any two numbers from the list add up to k

For example, given [10, 15, 3, 7] and k of 17, return true since 10 + 7 is 17.

Bonus: Can you do this in one pass?

这是谷歌很经典的一道题,在数组中寻找两个数,它们的和是否为k.

基本上所有的算法题,都有一个暴力解。我们就先从暴力解法开始。

注意:笔者会尽量使用新的C++语法来描述算法,而不是类C的代码风格。

Solution 1 暴力法:

#include <iostream>
#include <vector>
#include <algorithm>

bool TwoSum(std::vector<int> data, int k)
{
    int index = 1;
    auto iterFind = std::find_if(data.begin(), data.end(), [=, &index](int val){
        int leftSum = k - val;
        auto iter = std::find(data.begin() + index, data.end(), leftSum);
        index ++;
        if(iter != data.end())
        {
            return true;
       
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值