1.两数之和_两个数的和怎么算

1.两数之和_两个数的和怎么算1.两数之和

大家好,又见面了,我是你们的朋友全栈君。

num1

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

 

解法1: 直接的解法,两层循环,O(n2)的时间复杂度。

vector<int> twoSum(vector<int>& nums, int target) {
        vector<int> ret;
        for(int i=0 ; i<nums.size() ; ++i)
        {
            for(int j=i+1; j<nums.size(); ++j)
            {
                if(nums[i] + nums[j] == target)
                {
                    ret.push_back(i);
                    ret.push_back(j);
                    return ret;
                }
            }
        }

        return ret;
    }

 

解法2: 想要从两层循环变为一层循环,需要借助外部空间,将数据再保留一份出来。

vector<int> twoSumTwoLoopHash(vector<int>& nums, int target)
    {
        map<int, int> mp;
        vector<int> solution;
        for(int i=0; i<nums.size(); ++i)
            // mp.emplace(std::make_pair(nums[i], i));
            mp[nums[i]] = i;

        for(int i=0; i<nums.size(); ++i)
        {
            if(mp.count(target-nums[i]) != 0 && mp[target-nums[i]] != i)
            {
                solution.push_back(i);
                solution.push_back(mp[target-nums[i]]);
                break;
            }
        }

        return solution;
    }

 

解法3: 解法2将时间复杂度从O(n2)降低到O(n)。还可以将两次for循环减少为一个。

vector<int> twoSumOneLoopHash(vector<int>& nums, int target)
    {
        unordered_map<int, int> mp;
        vector<int> solution(2, -1);

        for(size_t i=0; i<nums.size() ; ++i)
        {
            if(mp.count(target-nums[i]) != 0 && mp[target-nums[i]] != i)
            {
                solution[0] = i;
                solution[1] = mp[target-nums[i]];
                break;
            }
            mp[nums[i]] = i;
        }

        return solution;
    }

 

转载于:https://www.cnblogs.com/jimobuwu/p/9755371.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/107272.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 行为识别综述

    行为识别综述定义背景难点最新论文最新算法数据集1定义行为识别:行为识别(ActionRecognition)任务是从视频剪辑(2D帧序列)中识别不同的动作,其中动作可以在视频的整个持续时间内执行或不执行。行为识别似乎是图像分类任务到多个帧的扩展,然后聚合来自每帧的预测。尽管图像分类取得了很大的成功,但是视频分类和表示学习依然进展缓慢。2背景2.1方法2.1.1传统方法提取视频区域的局部高维视觉特征,然后组合成固定大小的视频级描述,最后利用分类器(SVM,RF等)进行最终预测2.

  • Python暴力激活成功教程wifi密码

    Python暴力激活成功教程wifi密码今天给大家分享一个使用Python激活成功教程WiFi密码的代码,这个代码也是非常简单,这里需要用Python中的pywifi这个库,所以需要在DOS命令下安装这个库,同样使用pipinstallpywifi,很简单就安装成功了,我用的是Python3,所以各位看的时候需要注意这一点。接下来我们一步一步分析主要代码,后面同样附上完整的代码。对了,需要注意一点,就是电脑必须是要用无线网卡的。首先我们…

  • 企业 keepalived 高可用项目实战

    企业 keepalived 高可用项目实战Listitem企业keepalived高可用项目实战1、KeepalivedVRRP介绍keepalived是什么keepalived是集群管理中保证集群高可用的一个服务软件,用来防止单点故障。keepalived工作原理keepalived是以VRRP协议为实现基础的,VRRP全称VirtualRouterRedundancyProtocol,即虚拟路由冗余协议。虚拟路由冗余协议,可以认为是实现高可用的协议,即将N台提供相同功能的路由器组成一个..

  • c#打包安装程序[VS2010]「建议收藏」

    c#打包安装程序[VS2010]「建议收藏」一:创建创建Windows安装项目二:添加内容文件三:添加项目输出四:添加注册表信息五:创建快捷方式六:生成Windows安装程序

  • Apache规则RewriteCond详解

    Apache规则RewriteCond详解
    Apache中RewriteCond语句对于我来说一直是个难点,多次试图去把它搞明白,都没有结构,这次我终于算大概知道它的意思了。 RewriteCond就像我们程序中的if语句一样,表示如果符合某个或某几个条件则执行RewriteCond下面紧邻的RewriteRule语句,这就是RewriteCond最原始、基础的功能,为了方便理解,下面来看看几个例子。
      RewriteEngineon
      RewriteCond %{HTTP_USER_AGENT

  • BeanUtils_BeanUtils

    BeanUtils_BeanUtils使用maven创建项目,pom文件&lt;dependency&gt; &lt;groupId&gt;commons-beanutils&lt;/groupId&gt; &lt;artifactId&gt;commons-beanutils&lt;/artifactId&gt; &lt;version&gt;1.9.3&lt;/version&gt; &lt;/depende

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号