我们需要编写一个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]