Dev/🤦♀️깨달음
[C++] 최단 경로, 다익스트라
사과당근
2022. 2. 26. 00:40
의문의 시간 초과와의 싸움
1753을 다익스트라로 푸는데 endl 대신 \n도 썼고
ios::sync_with_stdio(false);
cin.tie(NULL);
도 사용을 했고
중복을 방지하기 위해
if(w>dist[v]) //중복을 방지하기 위해 (시간 단축)
continue;
도 사용을 했다.
이 부분이 헷갈렸는데 4->5->6 으로 가면 5이고 4->6으로 갈 때 7인 구간이 있다고 해보자
그러면 5을 거쳐 가는게 빠른데 계산을 하다가 4->6으로 가는 7인 구간을 또 거쳐가게 될 수도 있다. 그럴 때 중복을 방지하는 것이다. 당연히 5 만큼에 갈 수 있는 거리인걸 아는데 가중치 7을 가진 간선을 통해 가는 경로는 굳이 탐색해보지 않아도 되는것...
이 부분 때문에 시간 초과가 발생하는 다익스트라 문제도 있다고 한다.
그런데 이거까지 다 했는데 왜 시간 초과가 났을까?
내가 바보짓을 했기 때문이다~
priority_queue<pair<int,int>,vector<pair<int, int>>,greater<>> pq;
를 사용해서 가야할 정점과 그 정점까지 가는데의 가중치를 저장을 했다.
우선순위 큐를 사용한 이유는 가장 작은 가중치를 가진 정점을 빠르게 구하기 위해서였다.
greater<>을 사용해서 오름차순을 하면 pair의 첫 번째 요소를 기준으로 정렬이 된다.
그래서.. 가중치 순으로 정렬을 하고싶었으면
pq에 (가중치, 정점) 을 넣었어야 했는데 내가 pq에 (정점, 가중치)를 넣어서 시간 초과가 났던 것이다~
정신차리자^^
같은 실수를 반복하지 않기 위한 기록