有一个leetcode上的题:找到vector里相加等于target的数的下标。
比如:
nums = [2, 7, 11, 15], target = 9,
Because nums[0] + nums[1] = 2 + 7 = 9,
return [0, 1].
我是这么写的:
class Solution {
public:
vector twoSum(vector& nums, int target) {
vectornums_;
int i,j;
for(i=0;i<nums.size();++i){
for(j=i+1;j<nums.size();++j){
if(nums[i]+nums[j]==target){
nums_={i,j};
return nums_;
}
}
}
}
};
可是报错,
然后我抄了有一个答案发现加一句return vector();就运行正常了。
class Solution {
public:
vector twoSum(vector& nums, int target) {
vectornums_;
int i,j;
for(i=0;i<nums.size();++i){
for(j=i+1;j<nums.size();++j){
if(nums[i]+nums[j]==target){
nums_={i,j};
return nums_;
}
}
}
return vector<int>();
}
};
我想知道 return vector();到底是怎么回事,为什么不加它程序会报错?