目录
P5318 【深基18.例3】查找文献 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
思路:这道题就是先建图,然后dfs深搜输出,bfs宽搜输出就行了
完整代码:
#include <bits/stdc++.h>
#define int long long
const int N = 1e6 + 10;
std::vector<std::vector<int>> g(N);//建一个二维数组,输入x,y 把y放进x里面
int n, m;
bool vis[N]{};
void dfs(int cur) {
std::cout << cur << " ";//到了哪一层就输出哪一层
vis[cur] = true;
for (int i = 0; i < (int) g[cur].size(); i++)//遍历这一个节点连接的所有文献
{
if (vis[g[cur][i]] == false)//如果还没有输出
dfs(g[cur][i]);//继续搜索
}
}
void bfs() {
memset(vis, 0, sizeof(vis));//清空上一层dfs的
std::queue<int> q;//建一个队列
q.push(1);//因为是从1号节点开始所以把1放进去
vis[1] = true;//标记,后面的就不能走这条路了
while (!q.empty()) {
int cur = q.front();
q.pop();
std::cout << cur << " ";
for (int i = 0; i < (int) g[cur].size(); i++) {
if (vis[g[cur][i]] == false) {
q.push(g[cur][i]);
vis[g[cur][i]] = true;
}
}
}
}
signed main() {
std::cin >> n >> m;//输入数据
for (int i = 1; i <= m; i++) {
int x, y;
std::cin >> x >> y;
g[x].push_back(y);//把y放进x里面
}
for (int i = 1; i <= n; i++) {
std::sort(g[i].begin(), g[i].end());//一个节点可能连了多个文献,所以对这一个节点的文献进行排序
}
dfs(1);//从1号点开始搜索
std::cout << "\n";
bfs();
return 0;
}
P3916 图的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)
思路:这道题反向建图,然后依次遍历,输出答案就可以了
完整代码:
#include <bits/stdc++.h>
#define int long long
const int N = 1e5 + 10;
std::vector<std::vector<int>> g(N);
int n, m;
int a[N];
void dfs(int cur,int d)
{
if(a[cur]!=0)
return;
a[cur]=d;
for(int i = 0;i < g[cur].size();i ++)
{
dfs(g[cur][i],d);
}
}
signed main() {
std::cin >> n >> m;
for (int i = 1; i <= m; i++) {
int x, y;
std::cin >> x >> y;
g[y].push_back(x);
}
for (int i = n; i >= 1; i--) {
dfs(i,i);
}
for(int i = 1;i <= n;i ++)
{
std::cout<<a[i]<<" ";
}
return 0;
}