題解【洛谷P1948】[USACO08JAN]電話線Telephone Lines

題面c++

題解

很顯然,答案知足單調性。spa

所以,能夠使用二分答案求解。code

考慮\(check\)的實現。get

貪心地想,免費的\(k\)對電話線必定都要用上。it

每次\(check\)時將小於\(mid\)的邊權設爲\(0\),其它的設爲\(1\)class

跑一邊最短路判斷\(\mathrm{dist[n]}\)是否\(\leq k\)便可。queue

代碼

#include <bits/stdc++.h>
#define itn int
#define gI gi

using namespace std;

inline int gi()
{
    int f = 1, x = 0; char c = getchar();
    while (c < '0' || c > '9') {if (c == '-') f = -1; c = getchar();}
    while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return f * x;
}

const int maxn = 10003;

int n, p, k, dist[maxn], vis[maxn];
vector <int> v[maxn], edge[maxn], f[maxn];

inline bool check(int x)
{
    for (int i = 1; i <= n; i+=1)
    {
        int len = f[i].size();
        for (int j = 0; j < len; j+=1)
        {
            if (f[i][j] <= x) edge[i][j] = 0;
            else edge[i][j] = 1;
        }
    }//重設邊權
    queue <int> q;
    memset(dist, 0x3f, sizeof(dist));
    memset(vis, 0, sizeof(vis));
    vis[1] = 1;
    dist[1] = 0;
    q.push(1);
    while (!q.empty())
    {
        int u = q.front(); q.pop();
        vis[u] = 0;
        int len = v[u].size();
        for (int i = 0; i < len; i+=1)
        {
            int vv = v[u][i], w = edge[u][i];
            if (dist[vv] > dist[u] + w)
            {
                dist[vv] = dist[u] + w;
                if (!vis[vv]) q.push(vv);
            }
        }
    }
    return dist[n] <= k;
}

int main()
{
    //freopen(".in", "r", stdin);
    //freopen(".out", "w", stdout);
    n = gi(), p = gi(), k = gi();
    for (int i = 1; i <= p; i+=1)
    {
        int u = gi(), vv = gi(), w = gi();
        v[u].push_back(vv);
        v[vv].push_back(u);
        edge[u].push_back(w);
        edge[vv].push_back(w);//現邊權
        f[u].push_back(w);
        f[vv].push_back(w);//原邊權
    }
    int l = 0, r = 1000000000, ans = -1;
    while (l <= r)
    {
        int mid = (l + r) >> 1;
        if (check(mid)) ans = mid, r = mid - 1;
        else l = mid + 1;
    }
    printf("%d\n", ans);
    return 0;
}
相關文章
相關標籤/搜索