인프런 커뮤니티 질문&답변

Grid님의 프로필 이미지
Grid

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

3-C

3-C 실행 시간 질문드립니다.

작성

·

426

·

수정됨

0

안녕하세요 선생님, 강의 잘 듣고 있습니다!

제가 해당 문제를 먼저 풀고, 선생님의 모범 답안과 비교해서 다시 보고 있는데, 선생님의 답안 실행 시간의 경우 80ms인데, 제 풀이의 경우 500ms가 나와서 어떤 부분에서 이렇게 시간이 많이 걸리는지 질문 드립니다.

제가 생각했을 때, 제 풀이는 bfs를 사용했고, 선생님의 풀이는 dfs를 사용한 것이 가장 큰 차이인데, 관련해서 bfs를 이용해 문제를 푼 분의 비슷한 질문과 선생님의 답변을 읽어 봤는데, 제 코드가 특히 더 느려서 질문 드립니다.

감사합니다.

http://boj.kr/64d1e109011644a499285cf8df6422a5

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 Grid님ㅎㅎ

해당 코드에 주석을 달아봤는데요. 참고부탁드립니다.

 

#include <iostream>
#include <vector>
#include <queue>
#include <string.h>

using namespace std;

const int dys[4] = { -1, 1, 0, 0 };
const int dxs[4] = { 0, 0, -1, 1 };

void update(int i, int j, int N, int L, int R, bool& flag, bool visited[][51], int MAP[][51])
{
	vector<pair<int, int>> union_group;
	queue<pair<int, int>> q;
	int populations = MAP[i][j];
	int cnt = 1;
	union_group.push_back({ i, j });
	q.push({ i, j });
	visited[i][j] = true;
	while (q.empty() == false)
	{
		pair<int, int> curr = q.front();
		q.pop();
		for (int k = 0; k < 4; k++)
		{
			int ny = curr.first + dys[k];
			int nx = curr.second + dxs[k];
			if (ny < 0 || ny >= N || nx < 0 || nx >= N || abs(MAP[ny][nx] - MAP[curr.first][curr.second]) < L || abs(MAP[ny][nx] - MAP[curr.first][curr.second]) > R)
				continue;
			if (visited[ny][nx])
				continue;
			if (flag == false)
				flag = true;
			populations += MAP[ny][nx];
			cnt += 1;
			union_group.push_back({ ny, nx });
			q.push({ ny, nx });
			visited[ny][nx] = true;
		}
	}
	for (int i = 0; i < union_group.size(); i++)
	{
		MAP[union_group[i].first][union_group[i].second] = populations / cnt;
	}
}

int main()
{
    ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
	// 전역변수를 사용해주세요. : 교안 참고
   int answer = 0;
	int N, L, R;
	cin >> N >> L >> R;
	int MAP[51][51];
	for (int i = 0; i < N; i++)
	{
		for (int j = 0; j < N; j++)
		{
			cin >> MAP[i][j];
		}
	}
	while (true)
	{
		bool flag = false;
		bool visited[51][51];
      // 한번에 초기화 가능합니다. for문 쓰지 않아도.
		for (int i = 0; i < N; i++)
			memset(visited[i], false, sizeof(bool) * N);
		for (int i = 0; i < N; i++)
		{
			for (int j = 0; j < N; j++)
			{
				if (visited[i][j] == false)
				{
					update(i, j, N, L, R, flag, visited, MAP);
				}
			}
		}
		if (flag == false)
			break;
		answer += 1;
	}
   //endl을 쓰지 말아야 합니다. : 교안참고
	cout << answer << endl;
}
Grid님의 프로필 이미지
Grid

작성한 질문수

질문하기