分层图的四倍经验

做完冻结后在做这三道题,简直爆切,直接四倍经验\(STO\)

飞行路线

几乎跟冻结一模一样就不讲啦

#include <bits/stdc++.h>
using namespace std;
int n , m , k , ans = 0x3ffffff , s , ee;
int dis[10000010] , vis[10000010];
vector<pair<int , int> > e[1000010];
void work(){
    priority_queue<pair<int , int> > q; 
    memset(dis , 127 , sizeof(dis));
    dis[s + k * n] = 0;
    q.push(make_pair(0 , s + k * n));
    while(!q.empty()){
        int x = q.top().second;
        q.pop();
        if(vis[x]) continue;
        vis[x] = 1;
        for(int i = 0; i < e[x].size(); i++){
            int nx = e[x][i].first , w = e[x][i].second;
            if(dis[nx] > dis[x] + w){
                dis[nx] = dis[x] + w;
                q.push(make_pair(-dis[nx] , nx));
            }
        }
    }
}
int main(){
    cin >> n >> m >> k >> s >> ee;
    s++ , ee++;
    for(int i = 1; i <= m; i++){
        int x , y , z;
        cin >> x >> y >> z;
        x++ , y++;
        e[x].push_back(make_pair(y , z));
        e[y].push_back(make_pair(x , z));
        for(int j = 1; j <= k; j++){
            e[x + j * n].push_back(make_pair(y + n * (j - 1) , 0));
            e[x + j * n].push_back(make_pair(y + n * j , z));
            e[y + j * n].push_back(make_pair(x + n * (j - 1) , 0));
            e[y + j * n].push_back(make_pair(x + n * j , z));
        }
    }
    work();
    for(int i = 0; i <= k; i++) ans = min(dis[ee + i * n] , ans);
    cout << ans;
    return 0;
}

Telephone Lines S

这道题改了一点点,就是让你输出的是最长的一条电话线,在跑最短路的时候改一下就OK了:

#include <bits/stdc++.h>
using namespace std;
int n , m , k , ans = 0x3ffffff , s , ee;
int dis[10000010] , vis[10000010];
vector<pair<int , int> > e[1000010];
void work(){
    priority_queue<pair<int , int> > q; 
    memset(dis , 127 , sizeof(dis));
    dis[s + k * n] = 0;
    q.push(make_pair(0 , s + k * n));
    while(!q.empty()){
        int x = q.top().second;
        q.pop();
        if(vis[x]) continue;
        vis[x] = 1;
        for(int i = 0; i < e[x].size(); i++){
            int nx = e[x][i].first , w = e[x][i].second;
            if(dis[nx] > dis[x] + w){
                dis[nx] = dis[x] + w;
                q.push(make_pair(-dis[nx] , nx));
            }
        }
    }
}
int main(){
    cin >> n >> m >> k >> s >> ee;
    s++ , ee++;
    for(int i = 1; i <= m; i++){
        int x , y , z;
        cin >> x >> y >> z;
        x++ , y++;
        e[x].push_back(make_pair(y , z));
        e[y].push_back(make_pair(x , z));
        for(int j = 1; j <= k; j++){
            e[x + j * n].push_back(make_pair(y + n * (j - 1) , 0));
            e[x + j * n].push_back(make_pair(y + n * j , z));
            e[y + j * n].push_back(make_pair(x + n * (j - 1) , 0));
            e[y + j * n].push_back(make_pair(x + n * j , z));
        }
    }
    work();
    for(int i = 0; i <= k; i++) ans = min(dis[ee + i * n] , ans);
    cout << ans;
    return 0;
}

Revamping Trails G

也是很简单的,我就不水了:

#include <bits/stdc++.h>
using namespace std;
int n , m , k , ans = 0x3ffffff;
int dis[1000010] , vis[1000010];
vector<pair<int , int> > e[1000010];
void work1(){
    priority_queue<pair<int , int> > q; 
    memset(dis , 127 , sizeof(dis));
    dis[1 + k * n] = 0;
    q.push(make_pair(0 , 1 + k * n));
    while(!q.empty()){
        int x = q.top().second;
        q.pop();
        if(vis[x]) continue;
        vis[x] = 1;
        for(int i = 0; i < e[x].size(); i++){
            int nx = e[x][i].first , w = e[x][i].second;
            if(dis[nx] > dis[x] + w){
                dis[nx] = dis[x] + w;
                q.push(make_pair(-dis[nx] , nx));
            }
        }
    }
}
int main(){
    cin >> n >> m >> k;
    for(int i = 1; i <= m; i++){
        int x , y , z;
        cin >> x >> y >> z;
        e[x].push_back(make_pair(y , z));
        e[y].push_back(make_pair(x , z));
        for(int j = 1; j <= k; j++){
            e[x + j * n].push_back(make_pair(y + n * (j - 1) , 0));
            e[x + j * n].push_back(make_pair(y + n * j , z));
            e[y + j * n].push_back(make_pair(x + n * (j - 1) , 0));
            e[y + j * n].push_back(make_pair(x + n * j , z));
        }
    }
    work1();
    for(int i = 0; i <= k; i++) ans = min(dis[n + i * n] , ans);
    cout << ans;
    return 0;
}

原文链接: https://www.cnblogs.com/bzzs/p/13179014.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    分层图的四倍经验

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/357878

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月2日 上午11:59
下一篇 2023年3月2日 上午11:59

相关推荐