1. 两数之和
题目要求
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
“来源:力扣(LeetCode)
”
链接:https://leetcode-cn.com/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
题解
1、暴力循环
两次遍历。
第一次遍历,分别拿出第i个参数,
第二次遍历,分别拿出后边的所有参数j,与i对比,判断求和是否为目标值。
时间复杂度:O(n^2)
空间复杂度:O(1)
function towSum(nums, target) {
let result = []
if (Array.isArray(nums) && typeof target === 'number') {
for (let i = 0; i < nums.length; i++) {
for (let j = i + 1; j < nums.length; j++) {
if (nums[i] + nums[j] === target) {
result.push([
[nums[i], nums[j]],
[i, j]
])
}
}
}
}
return result
}
let result = towSum([1, 2, 3, 14, 11, 13, 21, 4, 23], 24)
console.log(result)
/* 结果:
[ [ [ 1, 23 ], [ 0, 8 ] ],
[ [ 3, 21 ], [ 2, 6 ] ],
[ [ 11, 13 ], [ 4, 5 ] ] ] */
2、优化求解
设置一个对象,映射i与target的差值为对象的key,value为i。
时间复杂度:O(n)
空间复杂度:O(1)
function towSum2(nums, target) {
if (!nums || !Array.isArray(nums)) return
let len = nums.length, differMap = {}
for (let i = 0; i < len; i++) {
let curNum = nums[i]
if (differMap[curNum] !== undefined) return [i, differMap[curNum]]
differMap[target - curNum] = i
}
}
let result2 = towSum2([1, 2, 3, 14, 11, 13, 21, 4, 23], 24)
console.log(result2)
用一个对象,键为当前值和目标值的差,值为当前值的下标。 对象结构伪代码:{ target - nums[i] : i }; 在仅有的一次循环中,如果对象的key等于当前遍历数组的值,说明当前数组的值就是之前遍历值与target的差。 即以对象key对应的value值为下标,该下标所在数组中的对应值,和当前遍历的值之和是target。 所以,对象key对应的value与当前遍历的i(数组下标)就是要找的那俩下标。
越努力,越幸运;阿门。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
2017-06-29 两列布局——但只用右浮动