본문 바로가기

알고리즘 · 코딩

[SWEA 1249] 보급로

SWEA 1249. [S/W 문제해결 응용] 4일차 - 보급로

문제 링크

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV15QRX6APsCFAYD 

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com


C++ 풀이

#include <iostream>
using namespace std;

#define MAX 100
#define QUEUE_MAX 10000

struct info {
	int dist;
	int x;
	int y;
};

int map[MAX][MAX]; //입력받는 보드
int dist[MAX][MAX]; //누적 거리 저장
info p_queue[QUEUE_MAX]; // priority queue
int q_size;
int min_distance;
int N;

//priority queue push
void q_push(info value) {
	if (q_size > QUEUE_MAX)
		return;

	p_queue[q_size] = value;

	int current = q_size;
	while (current > 0 && (p_queue[current].dist < p_queue[(current - 1) / 2].dist)) {
		info temp = p_queue[current];
		p_queue[current] = p_queue[(current - 1) / 2];
		p_queue[(current - 1) / 2] = temp;
		current = (current - 1) / 2;
	}
	q_size++;
}

//priority queue pop
info q_pop() {
	if (q_size <= 0)
		return { -1, 0, 0 };

	info value = p_queue[0];
	q_size--;
	p_queue[0] = p_queue[q_size];

	int current = 0;
	while (current * 2 + 1 < q_size) {
		int child;
		if (current * 2 + 2 == q_size)
			child = current * 2 + 1;
		else
			child = p_queue[current * 2 + 1].dist < p_queue[current * 2 + 2].dist ? current * 2 + 1 : current * 2 + 2;

		if (p_queue[current].dist < p_queue[child].dist)
			break;

		info temp = p_queue[current];
		p_queue[current] = p_queue[child];
		p_queue[child] = temp;
		current = child;
	}
	return value;
}

// 다익스트라 알고리즘
void dijkstra() {
	while (q_size > 0) {
		info i = q_pop();
		int d = i.dist, x = i.x, y = i.y;
		//상
		if (x > 0) {
			x--;
			if (dist[x][y] > d + map[x][y]) {
				dist[x][y] = d + map[x][y];
				if (x == N - 1 && y == N - 1)
					return;
				q_push({ dist[x][y], x, y });
			}
			x++;
		}
		//하
		if (x < N - 1) {
			x++;
			if (dist[x][y] > d + map[x][y]) {
				dist[x][y] = d + map[x][y];
				if (x == N - 1 && y == N - 1)
					return;
				q_push({ dist[x][y], x, y });
			}
			x--;
		}
		//좌
		if (y > 0) {
			y--;
			if (dist[x][y] > d + map[x][y]) {
				dist[x][y] = d + map[x][y];
				if (x == N - 1 && y == N - 1)
					return;
				q_push({ dist[x][y], x, y });
			}
			y++;
		}
		//우
		if (y < N - 1) {
			y++;
			if (dist[x][y] > d + map[x][y]) {
				dist[x][y] = d + map[x][y];
				if (x == N - 1 && y == N - 1)
					return;
				q_push({ dist[x][y], x, y });
			}
			y--;
		}
	}
}
	

int main() {
	int T;
	cin >> T;
	for (int tc = 1; tc <= T; ++tc) {
		q_size = 0;
		min_distance = QUEUE_MAX;
		cin >> N;
		for (int i = 0; i < N; ++i) {
			for (int j = 0; j < N; ++j) {
				scanf("%1d", &map[i][j]);
				dist[i][j] = QUEUE_MAX;
			}
		}
		dist[0][0] = 0;
		q_push({ 0, 0, 0 });
		dijkstra();
		cout << "#" << tc << " " << dist[N -1][N -1] << endl;
	}
	return 0;
}

우선순위 큐(Priority Queue) 구현 + 다익스트라(Dijkstra) 알고리즘을 활용하여 풀이하였다.

 

 

반응형

'알고리즘 · 코딩' 카테고리의 다른 글

[프로그래머스] 전력망을 둘로 나누기  (0) 2021.12.22
[백준 5620번] 가장 가까운 두 점의 거리  (0) 2021.11.06
[SWEA 1230] 암호문3  (0) 2021.10.27
[SWEA 1215] 회문1  (0) 2021.10.21
[SWEA 1221] GNS  (0) 2021.10.21