news 2026/5/26 1:56:37

两数之和 暴力解法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
两数之和 暴力解法

在 LeetCode 的入门题目中,“两数之和”(Two Sum)绝对是绕不开的经典。这道题看似简单,却能帮我们夯实数组遍历、条件判断等基础编程能力。今天就来聊聊这道题的暴力解法思路,以及完整的 C++ 实现。

题目回顾

给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值的那两个整数,并返回它们的数组下标。

注意:

  • 每种输入只会对应一个答案。
  • 你可以假设每种输入只会对应一个答案,且同一个元素不能使用两遍。
  • 你可以按任意顺序返回答案。

示例:输入:nums = [2,7,11,15], target = 9输出:[0,1]解释:因为 nums [0] + nums [1] = 2 + 7 = 9,所以返回 [0,1]。

暴力解法思路

暴力解法的核心逻辑非常直观:遍历所有可能的数对,检查它们的和是否等于目标值

具体步骤:

  1. 外层循环遍历数组中的每一个元素,下标记为i(从 0 开始,遍历到倒数第二个元素即可,因为内层会找后续元素);
  2. 内层循环遍历i之后的所有元素,下标记为j(从i+1开始,避免重复检查同一对数,也避免使用同一个元素两次);
  3. 对于每一对(nums[i], nums[j]),判断它们的和是否等于target
  4. 一旦找到符合条件的数对,立即返回它们的下标[i, j]
  5. 题目保证有且仅有一个答案,因此循环结束前必定能找到结果。

C++ 代码实现

cpp

运行

#include <vector> using namespace std; class Solution { public: vector<int> twoSum(vector<int>& nums, int target) { int i, j; // 外层循环:遍历到倒数第二个元素即可 for (i = 0; i < nums.size() - 1; i++) { // 内层循环:从i的下一个元素开始,避免重复 for (j = i + 1; j < nums.size(); j++) { // 找到和为target的数对,直接返回下标 if (nums[i] + nums[j] == target) { return {i, j}; } } } // 题目保证有解,此处仅为语法兼容 return {i, j}; } };

代码解析

  1. 变量定义:声明两个整型变量ij,分别作为外层和内层循环的下标;
  2. 外层循环i从 0 遍历到nums.size() - 2(因为nums.size() - 1是最后一个元素的下标,i到倒数第二个即可,j会取最后一个);
  3. 内层循环ji+1开始遍历到数组末尾,确保每个数对只检查一次;
  4. 条件判断:若nums[i] + nums[j] == target,直接返回包含下标ij的 vector;
  5. 兜底返回:题目明确有且仅有一个解,因此这行代码不会被执行,仅为满足函数的返回语法要求。

复杂度分析

  • 时间复杂度:O (n²)。外层循环执行 n 次,内层循环平均执行 n/2 次,总的时间复杂度为平方级。
  • 空间复杂度:O (1)。仅使用了常数个临时变量,没有额外开辟与输入规模相关的空间。

总结

暴力解法是两数之和最基础的解法,优点是思路简单、代码易实现,适合算法入门者理解 “遍历 + 匹配” 的核心思想;缺点是时间效率较低,当数组规模较大(如 n>10⁴)时,运行时间会显著增加。

后续还可以优化为哈希表解法(时间复杂度 O (n)),感兴趣的同学可以继续深入研究。刷题的核心不是记住答案,而是理解每一种解法的思路和适用场景,逐步培养算法思维。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 19:40:35

3步解锁Go语言Office自动化:unioffice实战指南

3步解锁Go语言Office自动化&#xff1a;unioffice实战指南 【免费下载链接】unioffice Pure go library for creating and processing Office Word (.docx), Excel (.xlsx) and Powerpoint (.pptx) documents 项目地址: https://gitcode.com/gh_mirrors/un/unioffice 还…

作者头像 李华
网站建设 2026/5/25 14:53:11

30、NIS与NFS网络服务使用指南

NIS与NFS网络服务使用指南 1. NIS相关操作 1.1 旧NIS实现的特殊条目插入 在使用旧的NIS实现(由NYS或glibc实现中的passwd和group文件的兼容模式支持)时,需要向文件中插入特殊条目,这些条目表示NIS派生记录将插入信息数据库的位置。这些条目可以添加在任意位置,但通常添…

作者头像 李华
网站建设 2026/5/26 5:00:00

大模型Agent落地实战:从核心原理到工业级任务规划器开发

个人首页&#xff1a; 永远都不秃头的程序员(互关) C语言专栏:从零开始学习C语言 C专栏:C的学习之路 本文章所属专栏&#xff1a;人工智能从 0 到 1&#xff1a;普通人也能上手的实战指南 目录 大模型Agent落地实战&#xff1a;从核心原理到工业级任务规划器开发 一、大…

作者头像 李华
网站建设 2026/5/26 5:18:23

史上最全Visio形状库

史上最全Visio形状库 【免费下载链接】史上最全Visio形状库分享 你是否在使用Microsoft Visio时&#xff0c;发现内置的形状库无法满足你的需求&#xff1f;你是否在寻找一个更全面、更丰富的形状库来提升你的绘图效率&#xff1f;那么&#xff0c;你来对地方了&#xff01;本仓…

作者头像 李华
网站建设 2026/5/25 15:02:32

如何快速构建AI工作流:cube-studio可视化编排终极指南

如何快速构建AI工作流&#xff1a;cube-studio可视化编排终极指南 【免费下载链接】cube-studio cube studio开源云原生一站式机器学习/深度学习AI平台&#xff0c;支持sso登录&#xff0c;多租户/多项目组&#xff0c;数据资产对接&#xff0c;notebook在线开发&#xff0c;拖…

作者头像 李华