BOJ 11657. νμλ¨Έμ
πββοΈ[Gold IV] νμλ¨Έμ - 11657
μ±λ₯ μμ½
λ©λͺ¨λ¦¬: 2340 KB, μκ°: 8 ms
λΆλ₯
벨λ§βν¬λ, κ·Έλν μ΄λ‘ , μ΅λ¨ κ²½λ‘
μ μΆ μΌμ
2024λ 3μ 5μΌ 11:31:33
λ¬Έμ μ€λͺ
Nκ°μ λμκ° μλ€. κ·Έλ¦¬κ³ ν λμμμ μΆλ°νμ¬ λ€λ₯Έ λμμ λμ°©νλ λ²μ€κ° Mκ° μλ€. κ° λ²μ€λ A, B, Cλ‘ λνλΌ μ μλλ°, Aλ μμλμ, Bλ λμ°©λμ, Cλ λ²μ€λ₯Ό νκ³ μ΄λνλλ° κ±Έλ¦¬λ μκ°μ΄λ€. μκ° Cκ° μμκ° μλ κ²½μ°κ° μλ€. C = 0μΈ κ²½μ°λ μκ° μ΄λμ νλ κ²½μ°, C < 0μΈ κ²½μ°λ νμλ¨Έμ μΌλ‘ μκ°μ λλμκ°λ κ²½μ°μ΄λ€.
1λ² λμμμ μΆλ°ν΄μ λλ¨Έμ§ λμλ‘ κ°λ κ°μ₯ λΉ λ₯Έ μκ°μ ꡬνλ νλ‘κ·Έλ¨μ μμ±νμμ€.
μ λ ₯
첫째 μ€μ λμμ κ°μ N (1 β€ N β€ 500), λ²μ€ λ Έμ μ κ°μ M (1 β€ M β€ 6,000)μ΄ μ£Όμ΄μ§λ€. λμ§Έ μ€λΆν° Mκ°μ μ€μλ λ²μ€ λ Έμ μ μ 보 A, B, C (1 β€ A, B β€ N, -10,000 β€ C β€ 10,000)κ° μ£Όμ΄μ§λ€.
μΆλ ₯
λ§μ½ 1λ² λμμμ μΆλ°ν΄ μ΄λ€ λμλ‘ κ°λ κ³Όμ μμ μκ°μ 무νν μ€λ μ μΌλ‘ λλ릴 μ μλ€λ©΄ 첫째 μ€μ -1μ μΆλ ₯νλ€. κ·Έλ μ§ μλ€λ©΄ N-1κ° μ€μ κ±Έμ³ κ° μ€μ 1λ² λμμμ μΆλ°ν΄ 2λ² λμ, 3λ² λμ, ..., Nλ² λμλ‘ κ°λ κ°μ₯ λΉ λ₯Έ μκ°μ μμλλ‘ μΆλ ₯νλ€. λ§μ½ ν΄λΉ λμλ‘ κ°λ κ²½λ‘κ° μλ€λ©΄ λμ -1μ μΆλ ₯νλ€.
πνμ΄
λ²¨λ§ ν¬λ μκ³ λ¦¬μ¦μ μ¬μ©ν΄μΌνλ λ¬Έμ μ΄λ€.
πμ 체 μ½λ
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include<iostream>
#include <fstream>
#include <vector>
#include <algorithm>
#include <math.h>
using namespace std;
struct Edge
{
int s, e, val;
};
const long long MAX = 1234567890;
int n, m;
long long dist[1000];
void solve()
{
cin >> n >> m;
vector<Edge> edges;
int a, b, c;
for (int i = 1; i <= m; ++i)
{
cin >> a >> b >> c;
edges.push_back({ a, b, c });
}
for (int i = 1; i <= n; ++i)
dist[i] = MAX;
dist[1] = 0;
for (int i = 1; i < n; ++i)
{
for (int j = 0; j < edges.size(); ++j)
{
int s = edges[j].s;
int e = edges[j].e;
int w = edges[j].val;
if (dist[s] != MAX && dist[s] + w < dist[e])
dist[e] = dist[s] + w;
}
}
for (int i = 0; i < edges.size(); ++i)
{
int u = edges[i].s;
int v = edges[i].e;
int w = edges[i].val;
if (dist[u] != MAX && dist[u] + w < dist[v])
{
cout << -1 << '\n';
return;
//dist[v] = MAX;
}
}
for (int i = 2; i <= n; ++i)
{
if (dist[i] == MAX)
cout << -1 << '\n';
else
cout << dist[i] << '\n';
}
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
freopen("input.txt", "rt", stdin);
solve();
return 0;
}