解题思路:若题目所给的数组是升序数组,那么可以采用双指针的思想去解决,在往期博客有写到【算法天天练】两数相加等于目标值+有序数组问题
但是此题目所给的数组(这里标为A)是无序的,所以解题思路会有所变化:
将目标值target 减去 索引为0的首个数 nums[0] ,将所得值放进一个新数组B,再用 indexOf() 方法去查找数组B里有无数组A的值,如此循环反复,直至 i == nums.length,若无则返回 -1 .
这篇文章可查看indexOf() 方法参数,返回值是什么:
Js:indexOf() 和 lastIndexOf() 的区别
算法代码如下:
var twoSum = function(nums, target) {
let length=nums.length;
let value=[];
for(var i=0;i<length;i++){
let tempNum=target-nums[i];
value.push(tempNum);
let index=value.indexOf(nums[i+1])
if(index>-1){
return [index,i+1]
break;
}
}
};