Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >leetcode 打卡,1. 两数之和

leetcode 打卡,1. 两数之和

作者头像
我乃小神神
发布于 2022-05-11 00:47:50
发布于 2022-05-11 00:47:50
21200
代码可运行
举报
文章被收录于专栏:前端基础前端基础
运行总次数:0
代码可运行

单纯记录一下自己要刷题的日子 2022年5月10号 目前凌晨12:14

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		输入:nums = [2,7,1,15], target = 9
		输出:[0,1]

	</body>
	<script>
		let nums = [2, 7, 0, 3, 4]
		let target = 9
		// 1:使用map 解
		var oneSum = function(nums, target) {
			const map = new Map()
			for (let i = 0; i < nums.length; i++) {
				const otherIndex = map.get(target - nums[i])
				if (otherIndex !== undefined) {
					//能匹配到返回当前map 中的value,及其当前的下标
					return [otherIndex, i]
				}
				//先存起来
				map.set(nums[i], i)
			}
		};
		console.log("1:使用map 解", oneSum(nums, target))
		// 2:直接for 循环匹配差值
		var twoSum = function(nums, target) {
			for (let i = 0; i < nums.length; i++) {
				let num = target - nums[i]
				let res1 = i
				let res2 = nums.indexOf(num, i + 1);
				if (res2 !== -1) {
					return [res1, res2]
				}
			}
		};
		console.log("2.直接for 循环匹配差值", twoSum(nums, target))
		// 3:直接for 循环
		var threeSum = function(nums, target) {
			for (let i = 0, len = nums.length; i < len - 1; i++) {
				for (let j = i + 1; j < len; j++) {
					if (nums[i] + nums[j] == target) {
						return [i, j]
					}
				}
			}
		};
		console.log("3:直接for 循环", threeSum(nums, target))
		// 4:map 哈希
		var fourSum = function(nums, target) {
		    const map = new Map()
		    for(let i = 0; i < nums.length; i++) {
		        const d = target - nums[i]
		        if(map.has(d)) {
		            return [map.get(d), i]
		        }
		        map.set(nums[i], i)
		    }
		};
		console.log("4:map 哈希", fourSum(nums, target))
		
	</script>
</html>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
01两数之和
在leetcode题解中看到了哈希表,建一个容器map,遍历数组,判断容器中是否有能使target - nums[i]符合题意的值,如果有输出,没有就将原数组中的这个数加到哈希表中,后续继续判断.
小丞同学
2021/08/16
1660
力扣 (LeetCode)-两数之和,有效的括号,两数相加
每天学习编程,让你离梦想更新一步,感谢不负每一份热爱编程的程序员,不论知识点多么奇葩,和我一起,让那一颗四处流荡的心定下来,一直走下去,加油,2021加油!欢迎关注加我vx:xiaoda0423,欢迎点赞、收藏和评论
达达前端
2021/03/22
3330
力扣 (LeetCode)-两数之和,有效的括号,两数相加
leetcode——两数之和【一】
Given an array of integers nums and an integer target, return indices of the two numbers such that they add up to target.
思索
2024/08/16
1080
leetcode第一题两数之和
主要意思就是一个函数有两个参数一个参数是数组,另一个参数是数字,数组内有几个值也都是数字,他们当中有两个数字加起来的和为函数的第二个参数也就是图片中的target
用户6256742
2022/07/06
1630
leetcode第一题两数之和
LeetCode:1. 两数之和
下面是我直接用AI写的: 在这个方法中,HashMap扮演了非常重要的角色。它允许我们在O(1)时间复杂度内检查一个数是否已经在之前遍历过的元素中出现过,并且还能够获取到这个数在数组中的索引。这种方法比暴力解法(即使用两层循环遍历数组)要高效得多,因为暴力解法的时间复杂度是O(n^2),而这种方法的时间复杂度是O(n)。
姓王者
2024/10/31
1550
LeetCode:1. 两数之和
LeetCode :1.两数之和 解题报告及算法优化思路
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
熙世
2019/08/07
8190
从零打卡leetcode之day 1--两数之和
不过心里才两个循环时间复杂度可是n的平方,心想肯定得超时,不过还是大胆提交一下提交,呵呵,居然通过了。。。。
帅地
2018/08/30
4910
Leetcode No.1 两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
week
2022/01/07
1810
力扣刷题---两数之和
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>力扣刷题---两数之和</title> </head> <body> </body> <script> let nums = [2, 8, 11, 1] let target = 9 /* * 两数之和:第一种解法 * 双重for 循环 相加得到值 */ let twoSum = function(nums, target) { f
我乃小神神
2020/12/01
2550
力扣刷题---两数之和
001. 两数之和 | Leetcode题解
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
苏南
2020/12/16
7430
001. 两数之和 | Leetcode题解
力扣题库练习
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回答案。 示例: 输入:nums = [2,7,11,15], target = 9 输出:[0,1] 解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1]
全栈程序员站长
2022/11/17
4730
力扣题库练习
【LeetCode】两数之和
package leetcode.editor.cn; //给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。 // // 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。 // // // // 示例: // // 给定 nums = [2, 7, 11, 15], target = 9 // //因为 nums[0] + nums[1] = 2 + 7 = 9 //所以返回 [0, 1] //
Jacob丶
2020/08/05
2810
LeetCode 1:两数之和 Two Sum
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
爱写bug
2019/10/15
4250
LeetCode 1:两数之和   Two Sum
算法_两数之和&中位数
你需要实现的函数 twoSum 需要返回这两个数的下标, 并且第一个下标小于第二个下标。注意这里下标的范围是 0 到 n-1。
OBKoro1
2020/10/27
2990
【刷穿 LeetCode】1. 两数之和(简单)
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回它们的数组下标。
宫水三叶的刷题日记
2021/02/20
3400
JS求两数之和
题目:给定一个整数数组nums,和一个目标值target,请在nums数组中找到两个数字相加等于target,输出这两个整数的下标。
剁椒鱼鳞
2023/05/23
1K0
JS求两数之和
LeetCode-1-两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
benym
2022/07/14
1920
LeetCode-1 两数之和
给定一个整数数组 nums和一个目标值 target,请你在该数组中找出和为目标值的那 两个整数,并返回他们的数组下标。 你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。 示例:
用户3470542
2019/06/26
6490
LeetCode-1 两数之和
一位未曾涉足算法的初学者收获
正如标题所言,在我四年的编程经历中就没刷过一道算法题,这可能与我所编写的应用有关,算法对我而言提升不是特别大。加上我几乎都是在需求中学习,而非系统性的学习。所以像算法这种基础知识我自然就不是很熟悉。
愧怍
2023/10/21
1980
一位未曾涉足算法的初学者收获
JavaScript刷LeetCode拿offer-js版字典
执行用时:56 ms, 在所有 JavaScript 提交中击败了99.77%的用户
hellocoder2028
2022/12/15
6580
相关推荐
01两数之和
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验