news 2026/4/16 10:37:55

两数之和 暴力解法

作者头像

张小明

前端开发工程师

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/4/11 7:21:23

32、IPX网络配置与管理全解析

IPX网络配置与管理全解析 1. IPX路由器配置 1.1 IPX路由协议基础 IPX是一种可路由协议,在IPX环境中,路由信息协议(RIP)用于传播路由信息。IPX版本的RIP与IP版本的RIP非常相似,路由器会定期广播其路由表内容,其他路由器通过监听和整合接收到的信息来学习路由。主机只需…

作者头像 李华
网站建设 2026/4/12 19:35:23

[表单]HTML Learn Data Day 1

弄了几天服务器&#xff0c;注册了一个域名&#xff0c;现在个人网站终于可以访问了 很简陋&#xff0c;毕竟html才学到第1天&#xff0c;后续慢慢美化&#xff0c;欢迎访问&#xff1a;reisentyan.cn 黑马程序员的课就是好&#xff0c;不长不短&#xff0c;内容细致度还不错…

作者头像 李华
网站建设 2026/4/15 14:34:46

图文转视频全流程:最后一步交给EmotiVoice

图文转视频全流程&#xff1a;最后一步交给 EmotiVoice 在短视频内容爆炸式增长的今天&#xff0c;一条高质量视频从策划到发布的周期被压缩到了以小时甚至分钟计。用户不再满足于静态图文的“看”&#xff0c;而是追求视听一体的“沉浸”。然而&#xff0c;真正让图文“活”起…

作者头像 李华
网站建设 2026/4/1 20:26:40

GetQzonehistory:一键备份QQ空间历史说说的实用工具

你是否曾经担心QQ空间里的那些珍贵回忆会随着时间流逝而消失&#xff1f;那些记录着青春岁月的说说、承载着友情记忆的留言、还有那些充满故事的照片&#xff0c;都是我们无法复制的数字资料。GetQzonehistory正是为解决这一需求而生的专业工具。 【免费下载链接】GetQzonehist…

作者头像 李华
网站建设 2026/4/12 9:40:02

4、增强现实应用的硬件检测与位置服务使用指南

增强现实应用的硬件检测与位置服务使用指南 硬件检测 在开发增强现实应用时,检测设备的硬件能力是至关重要的。以下将详细介绍如何检测音频、视频、陀螺仪等硬件组件的可用性。 音频能力检测 检测音频能力的步骤如下: 1. 添加框架 :需要将 AVFoundation Framework …

作者头像 李华
网站建设 2026/4/3 4:15:22

Lemonade SDK:解锁大型语言模型部署与性能优化的终极指南 [特殊字符]

在人工智能快速发展的今天&#xff0c;大型语言模型已成为推动技术进步的核心动力。然而&#xff0c;将这些强大的模型高效地部署到实际应用中&#xff0c;往往面临着诸多技术挑战。lemonade SDK的出现&#xff0c;为这一难题提供了完美的解决方案。 【免费下载链接】lemonade …

作者头像 李华