社区讨论

30 分 WA 求调 思路两遍 DFS

P2296[NOIP 2014 提高组] 寻找道路参与者 2已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@lo128sqv
此快照首次捕获于
2023/10/22 14:00
2 年前
此快照最后确认于
2023/11/05 15:40
2 年前
查看原帖
https://www.luogu.com.cn/record/129689903
rt,邻接表存个图,遍历并 dfs,统计到终点的连通性,再遍历判断能否放在路径中,再 dfs 一遍,计算这些点中最短路径长度。
CPP
#include <iostream>
#include <vector>
#include <cstring>
using namespace std;
int n, m, ans = 0x3f3f3f3f;
vector<int> a[10005];
bool ava[10005];
bool fava[10005];
bool vis[10005];
int s, t;
void dfs(int x) {
    vis[x] = true;
    if (x == t) {
        ava[x] = true;
        return ;
    }
    if (a[x].size() == 0) ava[x] = false;
    for (int j : a[x]) {
        if (!vis[j]) dfs(j);
        ava[x] |= ava[j];
    }
}
void fdfs(int x, int lg) {
    if (x == t) {
        ans = min(ans, lg);
        return ;
    }
    for (int j : a[x]) {
        if (fava[j] && !vis[j]) {
            vis[j] = 1;
            fdfs(j, lg + 1);
        }
    }
}
int main() {
    cin >> n >> m;
    for (int i = 1; i <= m; i++) {
        int u, v;
        cin >> u >> v;
        a[u].push_back(v);
    }
    cin >> s >> t;
//    memset(ava, 1, sizeof ava);
    ava[t] = fava[t] = true;
    for (int i = 1; i <= n; i++) {
        dfs(i);
    }
    memset(vis, 0, sizeof vis);
    for (int i = 1; i <= n; i++) {
        if (!a[i].empty()) fava[i] = true;
        for (int j : a[i]) {
            fava[i] &= ava[j];
        }
    }
//    for (int i = 1; i <= n; i++) {
//        cout << a[i].size() << " ";
//    }
//    cout << endl;
//    for (int i = 1; i <= n; i++) {
//        cout << ava[i] << " ";
//    }
//    cout << endl;
//    for (int i = 1; i <= n; i++) {
//        cout << fava[i] << " ";
//    }
//    cout << endl;
    if (!ava[s] || !fava[s]) {
        cout << -1 << endl;
        return 0;
    }
    fdfs(s, 0);
    cout << (ans == 0x3f3f3f3f ? -1 : ans) << endl;
    return 0;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...