打印图中矢量的弱分量
Print weak component of a graph vector of vectors
我正在编写一个C++程序,该程序必须使用图形。我对其中一种方法有点小问题。所以,我的结构看起来像
struct graph {
std::vector <std::vector<int>> gr;
};
我有一个方法,它必须返回源自顶点的弱组件内部的顶点,并且它只能用现有的顶点调用。
现在是:
std::vector<int> weak_component(const graph& g, int vertex) {
std::vector<int> ret;
if (vertex >= 0 && vertex < g.gr.size()) {
for (std::vector<std::vector<int>>::size_type i = 0;
i < g.gr[vertex].size(); i++) {
for (std::vector<int>::size_type j = 0; j < g.gr[i].size(); j++) {
std::fill(ret.begin(), ret.begin(), g.gr[i][j]);
std::cout << vertex;
}
}
}
return ret;
}
我正在尝试填充另一个向量并返回它。例如:如果我用数据填充测试图
0, 1
1, 2
1, 3
并且调用方法weak_component(g, 0)
,返回值应该是0, 1, 2, 3
。我的方法做错了什么?谢谢你的帮助。
更改此项:
for (std::vector<std::vector<int>>::size_type i = 0;
i < g.gr[vertex].size(); i++) {
for (std::vector<int>::size_type j = 0; j < g.gr[i].size(); j++) {
std::fill(ret.begin(), ret.begin(), g.gr[i][j]);
std::cout << vertex;
}
}
至:
for (int adj : g.gr[vertex]) {
for (int elem : g.gr[adj]) {
ret.push_back(elem);
std::cout << vertex;
}
}
除非迫不得已,否则不要使用索引。遍历范围。
你的fill
什么都不做。将其替换为push_back
,以便向返回值添加内容。
我还想添加一个sort
和unique
-erase
来清理它。
相关文章:
- 如何循环打印顶点结构
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 如何在c++中打印目录
- 有一个打印语句的函数是一种糟糕的编程实践吗
- 在线编译器中的分段C++没有打印消息
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 如何将结构插入到集合中并打印集合的成员
- 在循环C++中指定字符串之后,不会打印该字符串
- 以螺旋方式打印矩阵的程序.(工作不好)
- 从控制台中删除最后打印的元素
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 如何仅使用对象名称打印特定于对象的成员
- 回溯C++不打印函数,因此文件
- 在一定长度后从数组中打印时缺少整数
- 为什么这个 c++ 代码打印出长度 5,当我打印出字符串时,程序会自动终止?
- 在gem5中打印文件中的所有cache_blocks
- 打印数字图案
- Log4cpp:以UTC/GMT时区打印日期
- 打印图中矢量的弱分量