JavaScript中线性时间的两个和问题
我们需要编写一个JavaScript函数,该函数将数字数组作为第一个参数,将目标和作为第二个参数。
函数应该从数组中(连续的或非连续的)查找并返回两个这样的数字的索引,这些数字加起来得出目标总和(如果有的话)。条件是我们必须在线性时间(一次迭代)中执行此操作。
我们将使用映射来记录迭代次数,如果在任何时候遇到两个给出目标总和的数字,我们都会立即返回。
示例
为此的代码将是-
const arr = [1, 3, 5, 7, 9, 11];
const target = 16;
const twoSum = function(arr, target) {
const map = new Map();
for(let i = 0; i < arr.length; i++) {
let num = arr[i];
if(map.get(num) === undefined){
map.set(target−num, i)
}else{
return [map.get(num), i]
};
};
};
console.log(twoSum(arr, target));输出结果
控制台中的输出将是-
[3, 4]
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语