- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
// second try: correct but potentially slow
vector<Student_info> extract_fails(vector<Student_info>& students)
{
vector<Student_info> fail;
vector<Student_info>::size_type i = 0;
// invariant:elements [0, i) of students represent passing grades
while (i != students.size())
{
if (fgrade(students[i]))
{
fail.push_back(students[i]};
students.erase(students.begin() + i);
} else
++i;
}
return fail;
}
以上代码来自《Accelerated C++》一书,会计算用户分数。根据不及格或及格的成绩,将结果放入未及格学生的 fail
vector 中。 students
是包含将通过考试的学生的 vector
一切都很好,但是当我更改以下行时
students.erase(students.begin() + i);
到
students.erase(i);
我收到以下编译器错误:
error: no matching function for call to 'std::vector, std::allocator>::erase(size_t&)'
尽管我认为它们在功能上是相同的。谁能解释一下这是什么原因造成的?
最佳答案
“调用无匹配函数”基本上说明了一切。没有这种以“size_t”作为参数的删除函数。这就是可能看似奇怪的 students.erase(students.begin() + i);
首先出现的全部原因。
关于c++ - 使用 size_type 索引从 std vector 中删除会导致编译器错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8396991/
在我的 for 循环中声明迭代器时研究无符号整数与有符号整数比较警告时,I read this : Whenever possible, use the exact type you will be
我有一个 std::map, float>这占用了太多内存,为了使用更少的内存,我决定将唯一字符串映射到整数(例如 std::map ,其中每个新的唯一字符串都映射到 map 的当前 size() )
文档说,std::vector 的 size_type 是/usually/size_t,这是合理的,因为实现可以选择使用不同的。 但是为什么 size_type = size_t 位于 std::a
以下代码片段编译失败: #include #include #include #include using namespace std; vector list1{1,3,5,7,11}; s
我正在编写自定义算法,有时它需要获取两个迭代器之间的距离。如果我假设 it1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
std::vector的成员类型为size_type。它的printf格式说明符是什么? 请注意,size_type与size_t不同。 https://en.cppreference.com/w/c
我在这里浏览了一些关于 string::size_type 的线程,根据 C++ 标准,我确实理解这个 size_type 保证了所有字符串使用的足够分配。 我只是觉得很难相信。如果我将 C++ Pr
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我有一个类,它有一个类型为 vector 的私有(private)数据成员. 该类有两个实际使用vector::size_type 的公共(public)方法: 返回 vector 中元素个数的方法
在 C++ 模板中,我很难用正确的 size_type 定义变量。基本上,这将是容器中的索引类型。我知道 int 可以工作,但希望以干净的形式使用它。 template void test(Forwa
假设我有两种类型,Class1和 Class2 .然后我创建两个 vector : vector vec1; vector vec2; //create vec1 and vec2, such tha
我在一些非常有名的 C++ 书籍中看到 -- vector ivec; for (vector::size_type i = 0; i != 10; ++i) { ivec.push_back
我想以一种简单的方式编写基于索引的 for 循环。由于我的代码必须在 32 位和 64 位中运行,我收到很多关于隐式转换的警告,因为我通常使用 32 位整数,但 STL 在 64 位中使用 64 位整
我的背景主要是 R、SAS 和 VBA,我正在尝试学习一些 C++。我选择了“Accelerated C++”(Koenig,Moo)作为我关于该主题的第一本书。我在 comp 的理论背景。科学。诚然
下面的类不编译: template, class Allocator = std::allocator> class MyContainer { public: std::vector d
我经常有一些类,它们大多只是一些 STL 容器的包装器,如下所示: class Foo { public: typedef std::vector Vec; typedef Vec::size
显然,unordered_set::erase和 unordered_set::count返回一些不是严格 bool 值的东西(从逻辑上讲,也就是说,我不是在谈论实际类型)。 链接页面读取第三个版本的
#include #include using namespace std; int main() { vector student_marks(20); for (vector:
我一直在通过在不同平台上编译我的应用程序来对其进行一些测试,从 64 位系统到 32 位系统的转变暴露出许多问题。 我大量使用 vector 、字符串等,因此需要对它们进行计数。但是,我的函数也使用
我是一名优秀的程序员,十分优秀!