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

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

目录

​ 一.题目

二.解题过程

题目解析

 方法一(暴力求解)

思路

代码

提交结果

方法二(哈希查找)

思路

代码

提交结果


作者的个人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!

http://www.xdnf.cn/news/4163.html

相关文章:

  • Linux[Makefile]
  • ffmpeg录音测试
  • 爬虫程序中如何添加异常处理?
  • Vi/Vim 编辑器详细指南
  • Facebook如何运用AI实现元宇宙的无限可能?
  • DC-DC降压型开关电源(Buck Converter)设计中,开关频率(f sw​ )、滤波电感(L)和滤波电容(C out​ )的关系和取舍
  • uniapp 全局混入:监听路由变化,路由变化即执行
  • 嵌入式openharmony标准鸿蒙系统驱动开发基本原理与流程
  • openssl 生成自签名证书实现接口支持https
  • 【coze】手册小助手(提示词、知识库、交互、发布)
  • C++中指针使用详解(4)指针的高级应用汇总
  • 人工智能对人类的影响
  • 【Hive入门】Hive安全管理与权限控制:审计日志全解析,构建完善的操作追踪体系
  • kubeadm部署k8s
  • openwrt 使用quilt 打补丁(patch)
  • 基于图像处理的道路监控与路面障碍检测系统设计与实现 (源码+定制+开发) 图像处理 计算机视觉 道路监控系统 视频帧分析 道路安全监控 城市道路管理
  • 计算机视觉与深度学习 | 基于数字图像处理的裂缝检测与识别系统(matlab代码)
  • 【Python系列】Python 中的 HTTP 请求处理
  • OpenAI的“四面楚歌”:从营利到非营利,一场关于AGI控制权的革命
  • 信息时代的政治重构:网络空间与主权的未来
  • 搭建spark yarn 模式的集群
  • mybatis 的多表查询
  • Nacos源码—4.Nacos集群高可用分析四
  • 【Linux网络】应用层协议HTTP
  • Ubuntu18.04搭建samda服务器
  • ORACLE EBS 12.1 启用https 简单策略
  • 谷歌在即将举行的I/O大会之前,意外泄露了其全新设计语言“Material 3 Expressive”的细节
  • 如何通过外网访问内网?对比5个简单的局域网让互联网连接方案
  • 单应性估计
  • 《深入探索位操作符:Python、Java与C语言的实现与应用》