为什么在使用 STL 复制算法时出现"passing 'const Person' as 'this' argument discards qualifiers"?



我试图在用户定义的结构上实现最大堆,我使用std::copy_n()算法从heap.in文件中获取输入,但我从编译器收到了这种错误:

将"const Person"作为"this"参数传递将丢弃限定符

有人能告诉我问题出在哪里吗?

#include <fstream>
#include <vector>
#include <queue>
#include <utility>
#include <algorithm>
#include <functional>
#include <iterator>
#include <string>
#include <iostream>

std::ifstream fin ("heap.in");
std::ofstream fout ("heap.out");
struct Person {
int age;
std::string name;
bool operator < (const Person p) const{
if (this->age != p.age)
return this->age < p.age;
return this->name < p.name;
}
friend std::istream& operator >> (std::istream& flux, Person& p) {
flux >> p.name >> p.age;
return flux;
}
friend std::ostream& operator << (std::ostream& flux, Person p) {
flux << "(" << p.name << ", " << p.age << "); ";
return flux;
}
friend std::ifstream& operator >> (std::ifstream& flux, Person& p) {
flux >> p.name >> p.age;
return flux;
}
friend std::ofstream& operator << (std::ofstream& flux, Person p) {
flux << "(" << p.name << ", " << p.age << "); ";
return flux;
}
};
int n;
std::vector <Person> Heap;
int main () {
fin >> n; 
std::copy_n (Heap.begin (), n, std::istream_iterator <Person> (fin));
return 0;
}

我猜你是指这个

int main () {
fin >> n;
std::copy_n (std::istream_iterator <Person> (fin), n, std::back_inserter(Heap));
return 0;
}

std::copy_n将n个项从它的第一个参数复制到它的第三个参数。如果要附加到向量,则必须使用包装器std::back_inserter,因为std::copy_n本身不会增加向量的大小。

最新更新