当前位置: 首页 > news >正文

两数之和(暴力+哈希查找)

目录

​ 一.题目

二.解题过程

题目解析

 方法一(暴力求解)

思路

代码

提交结果

方法二(哈希查找)

思路

代码

提交结果


作者的个人gitee​​

作者的算法讲解主页▶️

每日一言:“愿你纵踩淤泥,也要心向光明。🌸🌸

​ 一.题目

题目链接

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

二.解题过程

题目解析

题目要求比较简单,只需要找到两个值的和等于目标值,可以通过暴力枚举直接找到,也可以使用哈希查找降低时间复杂度。

 方法一(暴力求解)

  • 思路

直接暴力枚举所有情况:两层for循环遍历数组,找出两个数的和刚好等于target的情况,然后返回这两个数的索引。时间复杂度:O(n^2)。

  • 代码

class Solution 
{
public:vector<int> twoSum(vector<int>& nums, int target) {//数组长度为len,两数之和为sumint len = nums.size(),sum = 0;//遍历数组for(int i = 0;i<len;i++)for(int j = i+1;j<len;j++){//求和sum = nums[i]+nums[j];//判断是否与目标值相等,相等就返回if(sum == target)return {i,j};}//假如以上条件都不满足,则返回[-1,-1](此举是为了照顾leetcode编译器,编译器要求必须要有一个返回值)return {-1,-1};}
};
  • 提交结果

方法二(哈希查找)

  • 思路

方法一时间复杂度较高,我们不妨使用哈希表来优化查找过程,哈希表每一次查找的时间复杂度是O(1)。已知目标值target和其中一个值value,则我们在哈希表中只需要查找target-value的值(代码中为key),这样我们在n个元素的数组中查找一个目标值的时间复杂度就是O(1)*n = O(n)。

  • 代码

class Solution 
{
public:vector<int> twoSum(vector<int>& nums, int target) {//创建哈希表unordered_map<int, int> hash;//遍历数组for (int i = 0; i < nums.size(); i++) {//初始化当前的值valueint value = nums[i];   //初始化要找的值key         int key = target - value;//在哈希表中找key,使entry指向key。如果没有找到的话就entry就指向hash.end()auto entry = hash.find(key);//没有指向end就说明找到了if (entry != hash.end()) {//返回这两个数的索引return {entry->second, i};}//如果哈希表中不存在值为key的元素,则将当前遍历到的元素及其索引存入哈希表,以便后续继续查找。hash[value] = i;}//最终没有找到符合要求的key,则返回[-1,-1],原因同方法一。return {-1,-1};}
};
  • 提交结果


觉得有帮助的话麻烦点个赞和关注吧,秋梨膏QAQ!

相关文章:

  • 《AI大模型应知应会100篇》第50篇:大模型应用的持续集成与部署(CI/CD)实践
  • Linux内核视角:线程同步与互斥的原理、实现与锁优化策略
  • 网络安全的范式革命:从被动防御到 AI 驱动的主动对抗
  • Kotlin Android开发过渡指南
  • Kotlin Lambda优化Android事件处理
  • AI服务器的作用都有哪些?
  • PDF内容搜索--支持跨文件夹多文件、组合词搜索
  • Axure :列表详情、列表总数
  • Linux 磁盘初始化与扩容操作手册
  • Blender 初学者指南 以及模型格式怎么下载
  • 电子电器架构 --- 网关转发时延解析
  • GEC6818蜂鸣器驱动开发
  • UE5 Daz头发转Blender曲线再导出ABC成为Groom
  • 【Django】REST 常用类
  • 2025年03月电子学会青少年软件编程 图形化二级考级真题——风车
  • HCIP(OSPF的优化)
  • 【计网】ICMP、IP、Ethernet PDU之间的封装关系
  • 微服务架构详解
  • 基于ASP.NET+MySQL实现待办任务清单系统
  • 宁德时代区块链+数字孪生专利解析:去中心化身份认证重构产业安全底座
  • 川大全职引进考古学家宫本一夫,他曾任日本九州大学副校长
  • 上海市政府常务会议部署提升入境旅游公共服务水平,让国际友人“无障碍”畅游上海
  • 大规模空袭也门一日后,以军又对也门萨那机场发出撤离警告
  • 老人刷老年卡乘车被要求站着?公交公司致歉:涉事司机停职
  • 准80后遵义市自然资源局局长陈清松任仁怀市委副书记、代市长
  • 魔都眼|石库门里看车展,五一来张园体验城市“漫时光”