DFS和用for_each替换
DFS and replacement with for_each
如何用for_each循环替换DFS()的for循环。请让我知道是否有其他有效的方法来创建图形或任何通过STL教授图形的网站,我基本上可以用于竞争性编程?
void DFS(int s)
{
visited[s] = true;
cout<<s<<" n";
for(vector<pair<int,int> >::iterator it=AdjList[s].begin();it!=AdjList[s].end();it++)
{
if(!visited[it->first])
{
//cout<<it->first<<endl;
DFS(it->first);
edgeTo[it->first]=s;
}
}
}
用于整个代码http://ideone.com/iXO9QO
DFS中的循环非常简单,所以我怀疑您是否需要使用for_each。供您参考,
vector<pair<int,int> >::iterator it=AdjList[s].begin();
可以只是
auto it=AdjList[s].begin();
使用auto关键字将大大减少代码的数量。
就我个人而言,我已经用STL实现了所有主要的图算法。看到你的代码,我认为你已经走上了竞争性编程的正确道路。虽然boost提供了各种现成的库,但STL足以实现图形算法。
相关文章:
- 模板参数替换失败,并且未完成隐式转换
- 如何用转义符替换字符串中的所有特殊字符
- 为什么除非添加括号,否则构造函数上的模板替换会失败?
- 在一个读写器队列中,我可以用volatile替换原子吗
- 用符号版本替换对函数的所有调用
- 如何通过替换顺序代码的while循环来添加OpenMP for循环
- 替换基于地图的所有引用
- 按平均值替换数组中的元素
- 我可以在这里替换什么,因为我不能在 C# 中使用隐式变量的 lambda 函数?
- 如何将字节数组元素替换为修改的十六进制 ASCII 符号?
- 初始化 std::vector 替换为单大括号而不是双大括号
- 删除/替换C++字符串中的多字符 (ÿû)
- 将 malloc 替换为数组
- 如何替换此示例代码片段中已弃用的handler_type_t或 boost::asio::handler_type?
- 如何在C++中用'\'替换''来处理转义序列?
- 替换密码:哪一个?
- 替换 C++17 中移除的绑定 1st
- 将 Boost MPL 容器替换为 C++17 功能
- C++:如何用单个命令替换复杂的迭代?
- C++ 替换字节数组中项的顺序