题目:
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
解题思路:
1.建立一个查找表;
2.使用循环计算每个数组中的值与目标值的差;
3.判断搜寻表中找到与差相同的值,则返回其index;
4.如果表中没有吧这个值的index和值存入搜寻表中
5.array_key_exists() 函数检查某个数组中是否存在指定的键名,如果键名存在则返回 true,如果键名不存在则返回 false。
代码:
class Solution {
/**
* @param Integer[] $nums
* @param Integer $target
* @return Integer[]
*/
function twoSum($nums, $target) {
$scanned = [];//建立一个搜寻表
for ($i = 0; $i < count($nums); $i++) {
$diff = $target - $nums[$i];//当前数字与目标值的差
if (array_key_exists($diff, $scanned)) {//搜寻表中找到与差相同的值,则返回其index
return [$scanned[$diff], $i];
}
$scanned[$nums[$i]] = $i;//把扫描过的数字其index和值存入搜寻表中
}
}
}