哈希表-1.两数之和-力扣(LeetCode)

时光荏苒,博主也是再次来到leetcode的起点了,今天的我早已不是过去的我,回归正题接下来开始我们的算法之旅吧

cpp 复制代码
int* twoSum(int* nums, int numsSize, int target, int* returnSize) {
    int* arr =(int*)malloc(sizeof(int)*2);
    * returnSize=0;
    for(int i = 0;i<numsSize-1;i++)
    {
        for(int j = i+1;j<numsSize;j++)
        {
            if(nums[i]+nums[j]==target)
            {
                arr[0]=i;
                arr[1]=j;
                * returnSize=2;
                return arr;
            }
        }
    }
    return arr;
}

ps.这是博主在今年1月17日,提交的代码,那时博主还很小白

一、题目解析

1、同一个元素不能使用两次

2、返回答案的顺序任意

二、算法原理

解法1:暴力解法(向后枚举)

解法2:暴力解法(由前向后枚举)

解法3:在解法2的基础上使用哈希表优化

1、为什么要用哈希表优化?

我们需要频繁的查找某一个元素,用哈希表可以达到O(1)的查找

2、该如何使用哈希表?

根据题目的需求,我们的哈希表中要存储<nums[i],i>,这里的i是对应的下标;在遍历元素时,先固定一个值nums[i],然后在哈希表中找target-nums[i],如果存在,则返回{hash[target-nums[i],i},如果不存在,则把nums[i]和i插入到哈希表中

为什么不在解法1的基础上用哈希表优化?

1、在一般情况下是可以的,我们把所有元素放到哈希表中,然后查找

2、但如果存在nums[i] = 4,target = 8时,在哈希表中查找,会违反题目条件,即相同元素使用两次,需要进行条件的特判,所以不在解法1的基础上优化

三、代码示例

解法1:暴力解法(向后枚举)

cpp 复制代码
//解法1:暴力枚举(向后枚举)
    vector<int> twoSum(vector<int>& nums, int target)
    {
        for(int i = 0;i<nums.size();i++)
        {
            for(int j = i+1;j<nums.size();j++)
                if(nums[i]+nums[j] == target)
                    return {i,j};
        }
        return {0,0};
    }

这里的{i,j}构造一个vector的匿名对象

解法2:暴力解法(由前向后枚举)

cpp 复制代码
//解法2:暴力解法(由前向后枚举)
    vector<int> twoSum(vector<int>& nums, int target)
    {
        for(int i = 0;i<nums.size();i++)
        {
            for(int j = 0;j<i;j++)
                if(i != j && nums[i]+nums[j] == target)
                    return {i,j};
        }
        return {0,0};
    }

解法3:在解法2的基础上使用哈希表优化

cpp 复制代码
 //解法3:哈希表优化
    vector<int> twoSum(vector<int>& nums, int target)
    {
        unordered_map<int,int>hash;
        for(int i = 0;i<nums.size();i++)
        {
            if(hash.count(target-nums[i]))
                return {hash[target-nums[i]],i};
            hash[nums[i]] = i;
        }
        return {0,0};
    }

看到最后,如果对您有所帮助,还请点赞、收藏和关注,一键三联支持一下,我们下期再见!

相关推荐
SuperCandyXu9 小时前
P2168 [NOI2015] 荷马史诗-提高+/省选-
数据结构·c++·算法·洛谷
running thunderbolt9 小时前
c++:SLT容器之set、map详解
开发语言·c++
“αβ”9 小时前
网络编程套接字(三)---简单的TCP网络程序
linux·服务器·网络·c++·网络协议·tcp/ip·套接字
lingran__9 小时前
速通ACM省铜第十四天 赋源码(Coloring Game)
c++·算法
会开花的二叉树10 小时前
实战:基于 BRPC+Etcd 打造轻量级 RPC 服务 —— 从注册到调用的完整实现
网络·数据库·c++·rpc·etcd
青草地溪水旁10 小时前
设计模式(C++)详解——命令模式(1)
c++·设计模式·命令模式
青草地溪水旁10 小时前
设计模式(C++)详解——命令模式(2)
c++·设计模式·命令模式
敲上瘾10 小时前
HTTP协议工作原理与生产环境服务器搭建实战
服务器·网络·c++·网络协议·http
Zfox_10 小时前
【C++项目】微服务即时通讯系统:服务端
数据库·c++·微服务·中间件·rpc·架构·即时通讯
清朝牢弟11 小时前
基于Win系统下PCL库入门到实践:IO模块之PCD文件的读写(附详细代码)
c++·pcl·pcd