제출 #1129135

#제출 시각아이디문제언어결과실행 시간메모리
112913512345678Cheap flights (LMIO18_pigus_skrydziai)C++17
100 / 100
540 ms59360 KiB
#include <bits/stdc++.h>

using namespace std;

const int nx=3e5+5;

#define ll long long

ll n, m, u, v, w, dp[nx], mx;
vector<pair<ll, ll>> d[nx];
map<pair<ll, ll>, ll> mp;

int main()
{
    cin.tie(NULL)->sync_with_stdio(false);
    cin>>n>>m;
    for (int i=1; i<=m; i++) cin>>u>>v>>w, d[u].push_back({w, v}), d[v].push_back({w, u}), dp[u]+=w, dp[v]+=w, mp[{min(u, v), max(u, v)}]=w;
    for (int i=1; i<=n; i++) 
    {
        mx=max(mx, dp[i]);
        sort(d[i].begin(), d[i].end());
        reverse(d[i].begin(), d[i].end());
        if (d[i].size()>1) 
        {
            ll x=d[i][0].second, y=d[i][1].second;
            if (mp.find({min(x, y), max(x, y)})!=mp.end()) mx=max(mx, d[i][0].first+d[i][1].first+mp[{min(x, y), max(x, y)}]);
        }
    }
    cout<<mx;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...