如何解决这里调用 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 行。 提前致谢,抱歉耽误您的时间!
解决方法
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 指针插入到 int 向量中)。如果要元素的索引,指针差才是正确的做法。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。