ZHAOXIN_UESTC 2019-07-05 11:27 采纳率: 100%
浏览 3073
已采纳

return vector<int>(); 是怎么发挥作用的?

有一个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();到底是怎么回事,为什么不加它程序会报错?

  • 写回答

3条回答 默认 最新

  • qtchen_1988 2019-07-05 11:39
    关注
     return vector<int>();是返回一个空vector
     不加的话;假如 if(nums[i]+nums[j]==target) 都不成立,这个函数就没有返回值。
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大
  • ¥15 使用spss做psm(倾向性评分匹配)遇到问题