首页 > 解决方案 > 此处调用 push_back 的匹配函数指的是什么?

问题描述

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;

class Solution
{
// you only need to find one solution , thats why we used break    
public: 
    vector<int> twoSum(vector<int>& num,int target)
    {
        vector<int>result;
        for(auto i = num.data();i!=num.data()+num.size();++i)
        {        
            auto vec2 = find(i+1,num.data()+num.size(),target-*i);
            if (vec2!=(num.data()+num.size()))
            {
                result.push_back(i-num.data());
                result.push_back(vec2-num.data());
                break;
            }    
        }
        return result;    
    }    
};

伙计们,我的疑问在于:

result.push_back(i-num.data());
result.push_back(vec2-num.data());

当我在两行代码上运行时,它运行良好。

但是当我将以上两行代码更改为:

result.push_back(i);
result.push_back(vec2);

它显示错误说没有匹配的成员函数调用 push_back。不是都显示了向量的位置吗?我的直觉是将 i 和 vec2 的位置值推回向量结果。这也是我对第一个 twoSum leetcode 问题的回答。伙计们请帮我解决这个问题,我发现很难区分以上 4 行。提前谢谢,对不起您的时间!

标签: c++algorithmdata-structures

解决方案


vector<int> data()是类型int *https://en.cppreference.com/w/cpp/container/vector/data,你曾经从那里auto声明i,所以它也是一个int *

result.push_back(i-num.data());正在做两个指针的差异,这很好。

result.push_back(i);正在做一些奇怪的事情(试图将一个 int 指针插入到一个整数向量中)。如果你想要元素的索引,指针差异是正确的方法。


推荐阅读