結果
| 問題 |
No.1320 Two Type Min Cost Cycle
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-12-18 05:57:34 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 588 ms / 2,000 ms |
| コード長 | 1,313 bytes |
| コンパイル時間 | 780 ms |
| コンパイル使用メモリ | 83,968 KB |
| 最終ジャッジ日時 | 2025-01-17 02:47:42 |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 57 |
コンパイルメッセージ
main.cpp:41:1: warning: ISO C++ forbids declaration of ‘main’ with no type [-Wreturn-type]
41 | main() {
| ^~~~
ソースコード
#include <string>
#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int T, N, M;
int U[2000], V[2000];
long long W[2000];
long long dijkstra(int src, int dst, int id) {
vector<vector<pair<int, long long>>> G(N);
for (int i = 0; i < M; ++i) if (i != id) {
G[U[i]].push_back(make_pair(V[i], W[i]));
if (T == 0) {
G[V[i]].push_back(make_pair(U[i], W[i]));
}
}
vector<long long> d(N, (long long)1e18);
priority_queue<pair<long long, int>> pq;
pq.push(make_pair(0, src));
d[src] = 0;
while (!pq.empty()) {
auto p = pq.top();
auto cost = -p.first;
auto u = p.second;
pq.pop();
if (d[u] < cost) continue;
for (auto e:G[u]) {
int v = e.first;
long long nd = d[u] + e.second;
if (d[v] > nd) {
d[v] = nd;
pq.push(make_pair(-nd, v));
}
}
}
return d[dst];
}
main() {
cin >> T >> N >> M;
for (int i = 0; i < M; ++i) {
cin >> U[i] >> V[i] >> W[i];
--U[i];--V[i];
}
long long INF = 1e18;
long long ans = INF;
for (int i = 0; i < M; ++i) {
ans = min(ans, dijkstra(V[i], U[i], i) + W[i]);
}
cout << (ans == INF ? -1 : ans )<< endl;
}