社区讨论
受不了啦,20分求助,球球了
P5318【深基18.例3】查找文献参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @m0rlj9ko
- 此快照首次捕获于
- 2024/09/07 11:39 去年
- 此快照最后确认于
- 2025/11/04 21:37 4 个月前
CPP
#include <iostream>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
typedef pair<int, int> PII;
const int N = 1000100, M = 1000010;
PII path[M];
int e[M], ne[M], h[N], idx, n, m, st[N], d[N];
bool cmp(PII a, PII b) {
if(a.first < b.first) {
return a > b;
}else if(a.first == b.first) {
if(a.second > b.second) return a > b;
else return b < a;
}else {
return b > a;
}
}
void add(int a, int b) {
e[idx] = b;
ne[idx] = h[a];
h[a] = idx++;
}
void dfs(int u) {
st[u] = 1;
printf("%d ", u);
for(int i = h[u]; i != -1; i = ne[i]) {
int j = e[i];
if(!st[j]) dfs(j);
}
}
void bfs() {
memset(st, 0, sizeof(st));
queue<int> q;
st[1] = 1;
q.push(1);
while(!q.empty()) {
int t = q.front();
printf("%d ", t);
q.pop();
for(int i = h[t]; i != -1; i = ne[i]) {
int j = e[i];
if(!st[j]) {
q.push(j);
st[j] = 1;
}
}
}
}
int main() {
cin >> n >> m;
memset(h, -1, sizeof(h));
for(int i = 0; i < m; i++) {
int a, b;
cin >> a >> b;
d[b]++;
path[i] = {a, b};
}
sort(path, path + m, cmp);
for(PII x : path) {
add(x.first, x.second);
}
dfs(1);
printf("\n");
bfs();
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...