题目 2695: 蓝桥杯2022年第十三届决赛真题-出差

#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
 
const int N = 1010;
const int INF = 0x3f3f3f3f;
int n, m, t[N], d[N];
bool vis[N];
struct Edge {
    int u, v, w;
    Edge(int u, int v, int w): u(u), v(v), w(w) {}//建立Edge结构体
};
struct Node {
    int u, d;
    bool operator < (const Node& a) const {
        return d > a.d;
    }
    Node(int u, int d): u(u), d(d) {} //建立Node结构体
};
vector<Edge> edges;
vector<int> G[N];
int dijkstra() {
    priority_queue<Node> q;
    q.push(Node(1, 0));
    memset(d, INF, sizeof(d));
    memset(vis, 0, sizeof(vis));
    d[1] = 0;
    while(!q.empty()) {
        Node x = q.top(); q.pop();
        if(vis[n])
            break;
        if(vis[x.u])
            continue;
        vis[x.u] = true;
        for(int i=0; i<G[x.u].size(); i++) {
            auto& e = edges[G[x.u][i]];
            if(e.v == n) {
                if(d[x.u] + e.w < d[e.v]) {//到达城市N不需隔离
                //也可输出时直接减去隔离时间
                    d[e.v] = d[x.u] + e.w;
                    q.push(Node(e.v, d[e.v]));
                }
 
            }
            else {
                if(d[x.u] + e.w + t[e.v] < d[e.v]) {
                    d[e.v] = d[x.u] + e.w + t[e.v];
                    q.push(Node(e.v, d[e.v]));
                }
            }
        }
    }
    return d[n];
}
 
int main() {
    cin>>n>>m;
    for(int i=1; i<=n; i++)
        cin>>t[i];
    int u, v, w;
    for(int i=0; i<m; i++) {
        cin>>u>>v>>w;
        edges.push_back(Edge(u, v, w));
        edges.push_back(Edge(v, u, w));//双向路线
        G[u].push_back(i*2);
        G[v].push_back(i*2+1);
    }
    int ans = dijkstra();
    cout<<ans<<endl;
}

转载于(5条消息) 2022年第十三届蓝桥杯大赛软件类决赛C/C++大学B组E题出差_行而不缀的博客-CSDN博客下面自己运行的代码,运行没有问题,但是检测会出现运行错误

#include<iostream>
using namespace std;
#include<limits.h>
int main()
{
    //输入
    int n,m,ci[2010],u[2010],v[2010],c[2010],tim=INT_MAX;
    cin>>n>>m;
     for(int i=1;i<=n;i++)
     {
         cin>>ci[i];
     }
     for(int j=1;j<=m;j++)
     {
         cin>>u[j]
            >>v[j]
            >>c[j];
     }
    for(int k=1;k<=m;k++){
    int t=0;
    int state=1;
    for(int j=k;j<=m;j++){
        if(u[j]==state)
        {
        state=v[j];
        if(state!=4) t=t+c[j]+ci[state];
        else {t=t+c[j]; break;}
        }
        }
        if(state==4 && t<tim) tim=t;
    }
    cout<<tim;
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值