알고리즘 모음(C++)

백준 1833 - 고속철도 설계하기(C++) 본문

백준

백준 1833 - 고속철도 설계하기(C++)

공대생의 잡다한 사전 2024. 2. 22. 23:28

문제 링크입니다. https://www.acmicpc.net/problem/1833

1833번: 고속철도 설계하기

첫째 줄에 자연수 N이 주어진다. 다음 N개의 줄에는 인접행렬 형태로 두 도시 사이에 고속철도를 설치할 때 드는 비용이 주어진다. 이 비용은 각각 10,000을 넘지 않는 자연수이다. 만약 비용이 음

www.acmicpc.net

최소 스패닝 트리를 이용한 문제입니다.

미리 연결된 도로들이 주어질 때, 남은 도로들로 모든 도시를 연결하려고 합니다.
이때의 연결된 도로 비용의 최솟값과 어떤 도로들이 추가로 연결되었는지를 출력해주면 됩니다.



자세한 것은 코드를 참고해주세요.

#define _CRT_SECURE_NO_WARNINGS
#include <vector>
#include <iostream>
#include <algorithm>
#include <queue>
#include <cmath>
#include <cstdio>
#include <cstring>

using namespace std;

int N;
typedef struct info{
	int x;
	int y;
	int cost;
}info;
vector<info> connect;
vector<pair<int, int>> line;
int parent[201];
int sum_cost;

void reset_parent(){
	for(int i = 1; i <= N; i++){
		parent[i] = i;
	}
}

bool cmp(info a, info b){
	if(a.cost < b.cost) return true;
	else return false;
}

void Union(int x, int y){
	if(x == y) return;
	if(x < y) parent[x] = y;
	else parent[y] = x;
}

int Find(int x){
	if(x == parent[x]) return x;
	else return parent[x] = Find(parent[x]);
}

void solve(){
	sort(connect.begin(), connect.end(), cmp);
	for(int i = 0; i < connect.size(); i++){
		int x = Find(connect[i].x);
		int y = Find(connect[i].y);
		if(x != y){
			Union(x , y);
			sum_cost += connect[i].cost;
			line.push_back({connect[i].x, connect[i].y});
		}
	}
	cout << sum_cost << " " << line.size() << "\n";
	for(int i = 0; i < line.size(); i++){
		cout << line[i].first << " " << line[i].second << "\n";
	}  
}

int main(){
	cin.tie(0);
	cout.tie(0);
	cin >> N;
	reset_parent();
	for(int i = 1; i <= N; i++){
		for(int j = 1; j <= N; j++){
			int cost;
			cin >> cost;
			if(cost < 0){
				if(i < j){
					sum_cost += -cost;
					Union(Find(i), Find(j));
				}
			}
			else if(cost > 0){
				connect.push_back({i, j, cost});
			}
		}
	}
	solve();
	return 0;
}


질문 및 조언은 댓글을 남겨주세요.

'백준' 카테고리의 다른 글

백준 4792 - 레드 블루 스패닝 트리(C++)  (3) 2024.02.29
백준 1185 - 유럽여행(C++)  (0) 2024.02.25
백준 23034 - 조별과제 멈춰!(C++)  (0) 2024.02.21
백준 23743 - 방탈출(C++)  (0) 2024.02.18
백준 13905 - 세부(C++)  (0) 2024.02.17