给一个整数数组,找到两个数使得他们的和等于一个给定的数 target。
你需要实现的函数twoSum
需要返回这两个数的下标, 并且第一个下标小于第二个下标。注意这里下标的范围是 1 到 n,不是以 0
开头。
注意事项
你可以假设只有一组答案。
给出 numbers = [2, 7, 11, 15]
, target = 9
, 返回 [1, 2]
.
用for循环在数组中寻找两个元素相加等于给定数值的元素,如果相加等于给定target,就将下标赋到新的数组中,返回新数组。注意下标范围是1到n,不是0到n-1。
class Solution {
public:
/*
* @param numbers: An array of Integer
* @param target: target = numbers[index1] + numbers[index2]
* @return: [index1 + 1, index2 + 1] (index1 < index2)
*/
vector<int> twoSum(vector<int> numbers, int target) {
vector<int> ret;
if(numbers.empty()){
return ret;
}
int len = numbers.size();
for(int i=0; i<len; i++){
for(int j=i+1; j<len; j++){
if(numbers[i] + numbers[j] == target){
ret.push_back(i+1);
ret.push_back(j+1);
}
}
}
return ret;
}
};