搜索矢量键会丢失
Vector key gets lost when searching through it
本文关键字:搜索 更新时间:2023-10-16
我的同类中有一个向量数组,该数组是将指针固定到特定对象指针的指针。
类应包含允许添加,删除和查找内部对象的方法。现在的课程看起来像这样:
class VectorKontener: public Kontener <VectorKontener> {
protected:
int find(Obiekt &n) {
cout << endl << "---------------------" << endl << "Running find method loop!" << endl;
for (int i = 0; i < stos.size(); i++) {
cout << "Now running for id: " << stos[i]->getId() << endl;
if (stos[i] == &n) return i;
}
return -1;
}
public:
VectorKontener::VectorKontener(Obiekt &n) {
add(n);
}
VectorKontener add(Obiekt &n) {
cout << "Adding: " << n.getId() << endl;
stos.push_back(&n);
return *this;
}
int checkPresent(Obiekt &n) {
return this->find(n) != -1;
}
VectorKontener remove(Obiekt &n) {
if (this->checkPresent(n)) {
stos.erase(stos.begin() + this->find(n));
}
else
cout << endl <<"ELEMENT NOT IN CONTAINER" << endl;
return *this;
}
VectorKontener display() {
cout << endl << "===DISPLAY===" << endl;
for (int i = 0; i < stos.size(); i++) {
stos[i]->display();
}
return *this;
}
};
但是,当运行以下测试数据时:
void Zad3()
{
Obiekt
obj1(5),
obj2(23),
obj3(234),
obj4(33);
cout << endl << "1. Class init" << endl;
VectorKontener k1(obj1);
cout << endl << "2. Adding other objects into array" << endl;
k1
.add(obj2)
.add(obj3)
.display();
cout << endl << "3. Element remove attempt" << endl;
k1
.remove(obj2)
.display();
getchar();
}
输出看起来像:
1. Class init
Adding: 5
2. Adding other objects into array
Adding: 23
Adding: 234
===DISPLAY===
This object has id: 5
This object has id: 23
This object has id: 234
3. Element remove attempt
---------------------
Running find method loop!
Now running for id: 5
Now running for id: 23
---------------------
Running find method loop!
Now running for id: 5
Now running for id: 23
===DISPLAY===
This object has id: 5
输出使数组的第三个变量似乎在 find 方法(hehe)中丢失,因为它没有由其计算,尽管stos.size()
显示了适当的值(2)。<<<<<<<<<<<<<<<</p>
我不是CPP专家,要远离它很远,并且知道这可能是一个非常鲁尼什的问题,但是我确实用尽了使它正常工作的方法。
任何帮助真的很棒
问题是对象的函数返回 copies ,这意味着在链式的 add
中调用原始对象(在第二个和任何后续的任何后续对象)函数调用),而是在每个函数调用上创建一个临时的调用。
简单的修复是将返回值更改为参考,例如:用于添加函数:
VectorKontener& add(Obiekt &n) {
而不是
VectorKontener add(Obiekt &n) {
和其他功能的类似变化。
相关文章:
- 有根的二进制搜索树.保留与其父级的链接
- 在C++中搜索嵌套多映射值
- cpp二进制搜索问题,计算给定数组中输入元素的出现次数
- 二进制搜索树叶数问题
- 为什么二进制搜索在我的测试中不起作用
- 正在尝试重载二进制搜索树分配运算符
- c++binary_search函数排序数组(流行名称搜索)出现问题
- 向量上的线性搜索
- 如何在动态数组上使用搜索函数
- 对于MacOS上的G++,如何添加默认的include目录/usr/local/include和默认的库搜索路径/usr
- cmake:添加要搜索头文件的目录
- 使用C++创建特殊的二叉搜索树
- 在C++的字符串中搜索和删除某些字符
- std::unordered_map 搜索算法是如何实现的?
- 使用不变量来确定二分搜索中的边界条件
- 二叉搜索如何比线性搜索更快?
- 按边长度递归搜索图中所有可行路径
- QStackWidget - 按名称搜索
- 在递归二叉搜索树中搜索
- 我的二进制搜索程序只是关闭了