前端面试题:两数和三数之和(多种方法实现以及数组中接近的值查找)

两数之和

前端面试中常被问到求两个数之和等于给定的值

如:在数组[2, 3, 5, 7, 11, 15]中找到两个数,使之和等于20,并返回这两个数的坐标,如果没有找到返回空[]

方法1

缺点:这种方法有局限性,首先需要对数组排序,带来额外的消耗

优点:对有序数组友好

实现方式:无序数组进行排序(有序直接查找),然后使用二分查找的方式进行,定义头尾两个指针,并进行数值求和并和目标值进行比较,小于目标值则左指针++,大于目标值右指针--,等于目标值则返回,找不到则返回空,实现方式如下:

function toNumberSum(arr, sum) {
	if (!arr.length) return [];
	let tmp = arr.sort((a, b) => a - b);
	
	let p = 0,
		q = tmp.length - 1;
	let res = [];
	while (p < q) {
		if (tmp[p] + tmp[q] === sum) {
			res = [p, q];
			return res;
		} else if (tmp[p] + tmp[q] < sum) {
			p++;
		} else {
			q--;
		}
	}
	return res;
}
测试
toNumberSum([2, 3, 5, 7, 11, 15], 27)

方法2

利用Map对象键值唯一性,使用目标值减去数组中的值作为键值,判断该键值是否存在,存在则找到,不存在继续循环数组,直到结束。

该方法适用于有序和无序数组

function twoNumberSum2(arr, sum) {
	if (!arr.le
  • 27
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

华子Code1024

您的认可与打赏是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值