news 2026/2/15 2:07:14

力扣解题步骤

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣解题步骤
核心思路回顾

通过哈希表存储「已遍历元素值 → 下标」的映射,遍历数组时计算当前元素的 “补数”(目标值 - 当前值),若补数存在于哈希表中,则直接返回结果;若不存在,将当前元素存入哈希表,继续遍历。

详细解题步骤

假设输入为vector<int> numsint target,最终返回vector<int>类型的下标数组,具体步骤如下:

步骤 1:引入必要头文件 & 命名空间

C++ 中需要引入vector(存储数组)和unordered_map(哈希表)的头文件,并用using namespace std;简化代码(也可显式写std::):

cpp

运行

#include <vector> // 用于存储数组和返回结果 #include <unordered_map> // 哈希表容器 using namespace std;
步骤 2:定义函数 & 初始化哈希表

函数返回值为vector<int>,参数为数组引用nums和目标值target;创建空的unordered_map,键为元素值(int),值为元素下标(int):

cpp

运行

vector<int> twoSum(vector<int>& nums, int target) { // 初始化哈希表:键=元素值,值=元素下标 unordered_map<int, int> hashMap;
步骤 3:遍历数组,逐个检查补数

使用for循环遍历数组,i为当前元素下标,nums[i]为当前元素值:

  1. 计算补数:complement = target - nums[i](需要找到的另一个数);
  2. 检查补数是否在哈希表中:
    • 若存在:返回哈希表中补数对应的下标 + 当前下标i
    • 若不存在:将当前元素值和下标存入哈希表,继续遍历。

代码实现:

cpp

运行

// 遍历数组,i为下标,nums[i]为当前元素 for (int i = 0; i < nums.size(); ++i) { int complement = target - nums[i]; // 计算补数 // 检查补数是否在哈希表中(find返回迭代器,end()表示未找到) if (hashMap.find(complement) != hashMap.end()) { // 找到则返回结果:补数下标 + 当前下标 return {hashMap[complement], i}; } // 未找到则将当前元素和下标存入哈希表 hashMap[nums[i]] = i; }
步骤 4:兜底返回(语法要求)

题目保证输入必有唯一答案,因此此处仅为满足函数语法要求,返回空数组:

cpp

运行

// 题目保证有解,此处仅兜底 return {}; }
步骤 5:测试函数(可选)

编写main函数测试示例用例,验证结果正确性:

cpp

运行

#include <iostream> // 用于输出结果 int main() { // 示例1:nums = [2,7,11,15], target = 9 vector<int> nums1 = {2, 7, 11, 15}; int target1 = 9; vector<int> res1 = twoSum(nums1, target1); cout << "示例1结果:[" << res1[0] << ", " << res1[1] << "]" << endl; // 示例2:nums = [3,2,4], target = 6 vector<int> nums2 = {3, 2, 4}; int target2 = 6; vector<int> res2 = twoSum(nums2, target2); cout << "示例2结果:[" << res2[0] << ", " << res2[1] << "]" << endl; // 示例3:nums = [3,3], target = 6 vector<int> nums3 = {3, 3}; int target3 = 6; vector<int> res3 = twoSum(nums3, target3); cout << "示例3结果:[" << res3[0] << ", " << res3[1] << "]" << endl; return 0; }

关键步骤解析(以示例 2 为例:nums = [3,2,4], target = 6)

遍历次数下标 i当前值 nums [i]补数 complement哈希表状态(存入前)检查结果哈希表状态(存入后)
1036-3=3未找到补数{3:0}
2126-2=4{3:0}未找到补数{3:0, 2:1}
3246-4=2{3:0, 2:1}找到补数 2(下标 1)无需存入

最终返回[1, 2],符合示例 2 结果。

暴力解法的解题步骤(对比参考)

若用暴力法,步骤如下(时间复杂度 O (n²)):

  1. 外层循环遍历每个元素,下标i从 0 到nums.size()-1
  2. 内层循环遍历i之后的元素,下标ji+1nums.size()-1
  3. 检查nums[i] + nums[j] == target,若满足则返回{i, j}
  4. 题目保证有解,无需处理无结果情况。

暴力法代码:

cpp

运行

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

核心注意点

  1. 哈希表选择unordered_map是哈希表,查找 / 插入平均 O (1);若用map(红黑树),时间复杂度会升至 O (logn),效率更低;
  2. 避免重复元素:先检查补数,再存入当前元素,确保不会使用同一个元素(如示例 3 的 [3,3]);
  3. 返回值:C++ 中直接返回vector<int>,满足 “返回数组下标” 的要求。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/8 10:40:25

【毕业设计】SpringBoot+Vue+MySQL 手机销售网站平台源码+数据库+论文+部署文档

摘要 随着移动互联网的普及和电子商务的快速发展&#xff0c;手机销售行业正经历着前所未有的变革。传统的线下销售模式已无法满足消费者对便捷、高效购物体验的需求&#xff0c;线上手机销售平台逐渐成为主流。手机作为现代人生活中不可或缺的智能设备&#xff0c;其市场需求持…

作者头像 李华
网站建设 2026/2/5 15:07:46

LLM - Prompt Engineering 构建工业级 LLM Agent 的六维结构化框架

文章目录Pre引言&#xff1a;从 Chat 到 Engineering一、 Role&#xff08;角色&#xff09;&#xff1a;不仅是身份&#xff0c;更是领域锚定1.1 明确专业领域 (Domain Specificity)1.2 单一职责原则 (SRP)1.3 避免角色冲突二、 Context&#xff08;上下文&#xff09;&#x…

作者头像 李华
网站建设 2026/2/10 7:45:03

【2025最新】基于SpringBoot+Vue的美食信息推荐系统管理系统源码+MyBatis+MySQL

摘要 随着互联网技术的快速发展和人们生活水平的不断提高&#xff0c;美食文化逐渐成为人们日常生活中不可或缺的一部分。美食推荐系统应运而生&#xff0c;旨在为用户提供个性化的美食信息推荐&#xff0c;帮助用户更高效地发现符合自身口味和需求的餐饮选择。传统的美食信息…

作者头像 李华
网站建设 2026/2/8 10:53:57

不滚动?局部滚动才高级:前端滚动区域实战指南

不滚动&#xff1f;局部滚动才高级&#xff1a;前端滚动区域实战指南页面不滚动&#xff1f;局部滚动才高级&#xff1a;前端滚动区域实战指南当整个页面“冻住”&#xff0c;只有部分内容在悄悄滑动滚动条的前世今生&#xff1a;从原生 overflow 到现代 CSS 新特性深入理解局部…

作者头像 李华
网站建设 2026/2/11 0:40:34

前后端分离大学生考勤系统系统|SpringBoot+Vue+MyBatis+MySQL完整源码+部署教程

摘要 随着信息技术的快速发展&#xff0c;传统的大学生考勤管理方式逐渐暴露出效率低下、数据易丢失、统计困难等问题。高校规模的扩大和教学管理的复杂化使得人工考勤难以满足现代化教育的需求。为了提高考勤管理的效率和准确性&#xff0c;设计并实现一套基于前后端分离架构的…

作者头像 李华