从邻接列表中移除边
Removing an edge from an adjacency list
本文关键字:列表 更新时间:2023-10-16
我使用邻接列表实现了一个图形,我现在正在尝试实现一个removeEdge函数。我能够使用邻接矩阵做到这一点,但对我来说该怎么做有点困惑。
这就是我到目前为止所拥有的,但擦除部分是错误的,所以只需要一些帮助来做什么。
/*
* C++ Program to Implement Adjacency List Graph Implementationn UNDIRECTED
*/
#include <iostream>
#include <vector>
const int V = 5;
std::vector<int> adj[V];
void addEdge(int u, int v) {
adj[u].push_back(v);
adj[v].push_back(u);
}
void removeEdge(int u, int v) {
adj[u].erase(v);
adj[v].erase(u);
}
void print() {
for (int v = 0; v < V; ++v) {
std::cout << "n Adjacency list of vertex "
<< v << "n head ";
for (auto x : adj[v])
std::cout << "-> " << x;
}
std::cout << "n";
}
int main() {
int V = 5;
addEdge(0, 1);
addEdge(0, 4);
addEdge(1, 2);
addEdge(1, 3);
addEdge(1, 4);
addEdge(2, 3);
addEdge(3, 4);
print();
removeEdge(2, 3);
print();
std::cin.get();
}
如果有人有一些建议,我将不胜感激。
使用iterator
查找要删除的元素。之后,使用erase
方法将其删除。
void removeEdge(int u, int v) {
// remove edge from u to v
vector<int>::iterator it = std::find(adv[u].begin(), adv[u].end(), v);
adv[u].erase(it);
// remove edge from v to u
it = std::find(adv[v].begin(), adv[v].end(), u);
adv[v].erase(it);
}
相关文章:
- Pybind11:将元组列表从Python传递到C++
- 从链接列表c++中删除一个项目
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- C++如何通过用户输入删除列表元素
- 读取文件的最后一行并输入到链接列表时出错
- 复制列表初始化的隐式转换的等级是多少
- LNK2038、MSVS2017 MAGMA的原因列表
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 没有为自己的结构调用列表推回方法
- 使用简单类型列表实现的指数编译时间.为什么
- 一对向量构造函数:初始值设定项列表与显式构造
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 通过for循环使用用户输入填充列表
- C++:如何使函数只返回作为列表一部分的字符串
- 概念中的cv限定符需要表达式参数列表
- 下面是我为检测链接列表中的循环而制作的代码
- 建议在运行时将带有类实例的列表从c++导入qml
- 如何维护资源管理器项目视图中当前可见的项目列表
- 在卡萨布兰卡形成编码参数的列表
- 在没有参数列表的情况下使用模板名称"Event"无效,模板问题