公园【百度之星】/图论+dijkstra

公园

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

图论+dijkstra

在这里插入图片描述

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll,ll> pii;
vector<ll> v[40005];
//a、b、c分别是小度、度度熊、终点到各个点的最短距离
ll a[40005],b[40005],c[40005],dist[40005],st[40005];
void dij(ll idx,ll e)
{
    memset(st,0,sizeof(st));
    memset(dist,0x3f,sizeof(dist));
    dist[idx]=0;
    priority_queue<pii,vector<pii>,greater<pii>> q;
    q.push({0,idx});
    while(!q.empty())
    {
        pii p=q.top();
        q.pop();
        ll a=p.first;
        ll b=p.second;
        if(st[b]) continue;
        st[b]=1;
        for(ll i=0;i<v[b].size();i++)
        {
            ll c=v[b][i];
            if(dist[c]>a+e)
            {
                dist[c]=a+e;
                q.push({dist[c],c});
            }
        }
    }
}
int main()
{
    ll te,fe,s,t,f,n,m;
    cin>>te>>fe>>s>>t>>f>>n>>m;
    for(int i=0;i<m;i++)
    {
        ll a,b;
        cin>>a>>b;
        v[a].push_back(b);
        v[b].push_back(a);
    }
    dij(t,te);
    for(ll i=1;i<=n;i++) a[i]=dist[i];
    dij(f,fe);
    for(ll i=1;i<=n;i++) b[i]=dist[i];
    dij(n,fe+te-s);
    for(ll i=1;i<=n;i++) c[i]=dist[i];
    ll res=0x3f3f3f3f;
    for(ll i=1;i<=n;i++)
    {
        if(a[i]>=0x3f3f3f3f||b[i]>=0x3f3f3f3f||c[i]>=0x3f3f3f3f) continue;
        res=min(res,a[i]+b[i]+c[i]);
    }
    if(res>=0x3f3f3f3f) cout<<-1<<endl;
    else cout<<res<<endl;
    return 0;
}

相关推荐

  1. 星2022题目记录

    2024-06-05 20:20:06       9 阅读
  2. 星2024题目记录

    2024-06-05 20:20:06       46 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-05 20:20:06       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-05 20:20:06       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-05 20:20:06       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-05 20:20:06       18 阅读

热门阅读

  1. 宝塔Linux面板-Docker管理(2024详解)

    2024-06-05 20:20:06       9 阅读
  2. 深度学习中域泛化的简要概述

    2024-06-05 20:20:06       8 阅读
  3. 【设计模式】工厂模式(创建型)⭐⭐⭐

    2024-06-05 20:20:06       7 阅读
  4. 封装PHP用于发送GET和POST请求的公共方法

    2024-06-05 20:20:06       10 阅读
  5. Elasticsearch 认证模拟题 - 6

    2024-06-05 20:20:06       7 阅读
  6. Elasticsearch (ES)内存管理降低内存占用率

    2024-06-05 20:20:06       7 阅读
  7. 高通Android 12/13实现USB拔出关机功能

    2024-06-05 20:20:06       7 阅读
  8. git命令

    git命令

    2024-06-05 20:20:06      7 阅读