有一个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();到底是怎么回事,为什么不加它程序会报错?
return vector<int>();是返回一个空vector
不加的话;假如 if(nums[i]+nums[j]==target) 都不成立,这个函数就没有返回值。
如果没有最后那句return,如果传入了一个空数组或者一个结果也找不到,那么你的函数就没有任何返回了,函数声明有返回,实际会跑到没有返回的代码,导致编译不通过。
不知道你这个问题是否已经解决, 如果还没有解决的话: