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

力扣HOT100之哈希:1. 两数之和

这道题之前刷代码随想录的时候已经刷过好几遍了,看到就直接秒了。这道题主要是通过unordered_map<int, int>来建立哈希表,其中键用来保存向量中的元素,而对应的值则为元素的下标。遍历整个向量,当遍历到nums[i]时,立马检查target-nums[i]是否在哈希表中,如果在,直接返回哈希表中对应键的值和当前遍历到的元素下标,如果不在,就直接将{nums[i], i}作为键值对添加到哈希表中。
特别要注意的是,这道题不需要额外考虑相加为target的两个数为同一位置的数,这种情况不可能发生。因为当第一次遍历到这个数时,哈希表中还没有存储该数,所以第一次遍历到它时会直接将其添加到哈希表中,当第二次遍历到大小相同的值时,由于哈希表中存储的是上一个相同值的下标,一定不可能是当前元素的下标,所以这种情况无需考虑。

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int, int> hash;
        for(int i = 0; i < nums.size(); i++){
            auto it = hash.find(target - nums[i]);
            if(it != hash.end())
                //找到和为target的两个数且这两个数一定不是同一个位置上的数
                return {i, it -> second};
            else
                hash[nums[i]] = i;
        }
        return {};
    }
};

http://www.kler.cn/a/571594.html

相关文章:

  • MySQL执行更新SQL流程
  • 【存储中间件】MyCat2应用与实战(二):安装与启动
  • 城市管理综合执法系统源码,B/S模式与手机等移动终端架构,java语言开发,可扩展性强
  • 在Spring Boot项目中导出复杂对象到Excel文件
  • Spring 源码硬核解析系列专题(六):Spring MVC 的请求处理源码解析
  • 简单的SQL语句以及使用Node.js连接MySQL
  • PYTHON常用指令
  • 【区块链 + 智慧政务】上海市城乡建设和交通发展研究院:基于联盟链的城市停车收费应用示范 | FISCO BCOS 应用案例
  • 服务降级
  • Ollama进行DeepSeek本地部署存在安全风险解决方案,nginx反向代理配置
  • 关于opencv中solvepnp中UPNP与DLS与EPNP的参数
  • BambuStudio学习笔记:Extruder 类
  • AI 外呼产品架构解读:让智能外呼更精准高效
  • Rust编程实战:初探WebAssembly
  • PyCharm 无法识别 Conda 环境的解决方案
  • python-leetcode-不同的二叉搜索树
  • JavaScript 交换变量案例
  • 学习 Wireshark 分析 Android Netlog
  • 【零基础到精通Java合集】第二十二集:CMS收集器详解(低延迟的里程碑)
  • nginx accesslog 打印自定义header