inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Hoàn thành C++ Coding Test trong 10 tuần | Thuật toán Coding Test

3-C

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

489

Grid

25 câu hỏi đã được viết

0

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

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

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

감사합니다.

http://boj.kr/64d1e109011644a499285cf8df6422a5

c++ 코딩-테스트 C++ 코테 준비 같이 해요!

Câu trả lời 1

0

kundol

안녕하세요 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;
}

2주차 개념#12 트리 순회

0

9

2

백준사이트가 종료된다고 합니다.

0

201

2

백준 서비스 종료

9

637

1

sk 하이닉스 코테 대비

0

346

2

3-G 최댓값 질문

0

46

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

77

2

3-I 코드 질문드립니다.

0

59

2

3-N 질문 있습니다.

0

63

2

학습방법

0

98

2

4-H 질문 있습니다 (코드 리뷰)

0

65

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

161

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

68

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

62

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

48

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

66

2

함수별 시간복잡도

0

71

2

3-h 질문입니다.

0

47

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

51

2

1-I 문제 질문 드립니다.

0

74

2

2-P 질문입니다.

0

55

1

mac에서 시작하기 관련

0

86

2

5-Q 질문

0

62

2

풀이 코드 질문

0

62

2

맞왜틀

0

68

2