본문 바로가기

Algorithm/Graph - Shrotest Path

ROUTING

#include <iostream>
#include <vector>
#include <queue>

using namespace std;

#define MAX_V 10000
#define INF 99999

vector<pair<int, float>> adj[MAX_V];

vector<float> dijkstra(int v, int src);

int main()
{
	int caseNum;

	cin >> caseNum;

	for (int cIter = 0; cIter < caseNum; cIter++)
	{
		int n, m;
		cin >> n >> m; 

		int start, end;
		float cost;

		for (int i = 0; i < m; i++)
		{
			cin >> start >> end >> cost;
			adj[start].push_back(make_pair(end, cost));
		}

		vector<float> dist = dijkstra(n, 0);

		cout.precision(10);
		cout << fixed << dist[n - 1] << endl;
	}
}

vector<float> dijkstra(int v, int src)
{
	vector<float> dist(v, INF);
	dist[src] = 1;
	priority_queue<pair<float, int>> pq;
	pq.push(make_pair(-1, src));

	while (!pq.empty())
	{
		float cost = -pq.top().first;
		int here = pq.top().second;
		pq.pop();

		if (dist[here] < cost) continue;

		for (int i = 0; i < adj[here].size(); i++)
		{
			int there = adj[here][i].first;
			float nextCost = cost * adj[here][i].second;

			cout << "here: " << here << " / there: " << there 
				<< " / here cost: " << cost << " / there cost: " << nextCost << endl;

			if (dist[there] > nextCost)
			{
				pq.push(make_pair(-nextCost, there));
				dist[there] = nextCost;
			}
		}

	}

	return dist;
}

 

RoutingInput.txt
0.00MB
RoutingOutput.txt
0.00MB

 

 

이 문제에서 나는 기존의 다익스트라 알고리즘에서 cost를 합으로 계산하던 방식을 곱으로 계산하는 방식으로 바꾸었다. 기존처럼 cost의 합을 사용하려면 문제로 나온 각 간선의 가중치에 log를 취한 후, 이 log값들의 합을 계산하는 방식으로 구현할 수 있다. 다익스트라 알고리즘 예제용으로 구현해보기 좋다. 

반응형

'Algorithm > Graph - Shrotest Path' 카테고리의 다른 글

PROMISES  (0) 2021.02.11
DRUNKEN  (0) 2021.02.11
TIMETRIP  (0) 2021.02.10
NTHLON  (0) 2021.02.08
FIRETRUCKS  (0) 2021.02.08