#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题出差_行而不缀的博客-优快云博客下面自己运行的代码,运行没有问题,但是检测会出现运行错误
#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;
}