inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-J

3-J 주난이의 난

169

작성자 없음

작성한 질문수 0

0

안녕하세요 큰돌선생님

선생님 덕분에 점차 백준 문제들을 생각하고 풀수 있게 되고 골드 문제까지도 한번씩 맞추다 보니 행복하게 코테 준비를 하고 있습니다. 감사합니다

 

https://www.acmicpc.net/submit/14497/83745509
위의 링크처럼 코드를 작성하면 시간초과가 발생하지만
dfs() 함수 부분에서 if(arr[y][x] == '0') 이부분을 없애고 아래와 같이 고치면 맞다고 뜨는데 어떤 이유에서 그런걸까요?

for(int i=0; i<4; i++){

int ny = y + dy[i];

int nx = x + dx[i];

if(ny < 0 || nx < 0 || ny >= n || nx >= m) continue;

if(visited[ny][nx]) continue;

if(arr[y][x] == '1'){

v.push_back({y,x});

continue;

}

dfs(ny,nx);

}

c++ 코딩-테스트

답변 3

0

큰돌

안녕하세요 미나리님 ㅎㅎ

먼저 코드리뷰를 드리면요.

		if(arr[ny][nx] == '0')
			dfs(ny,nx);
		if(arr[y][x] == '1'){
			v.push_back({y,x});
			continue;
		}

이런 코드는 좋지 않습니다. ny, nx로 방문처리 등을 판단하는데 -> 그다음 갑자기 지금의 y, x를 기반으로 로직이 있는 것은 이상합니다. 로직자체가 꼬일 가능성이 높은 코드입니다.

예를 들어 00011 이라고 가정했을 때.

ny, nx가 0일 떄 -> dfs를 거는데 만약 왼쪽 끝 0에서 시작을 하면 ->

dfs -> dfs -> dfs 까지 왔고 그 다음 1까지 dfs가 안갈 것 같습니다. ny, nx가 1을 가리키는데 -> arr[y][x]는 0만을 가리키기 때문입니다. 이 때문에 올바른 continue가 일어나지 않을 수 있습니다.

 

if(visited[ny][nx]) continue;


if(arr[y][x] == '1'){

v.push_back({y,x});

continue;

}

dfs(ny,nx);

}

이 코드 또한 이상하지만, 만약 지금의 y, x가 1이라면 -> 지워야 하기 때문에 일단 넘어가 -> 그게 아니라면 -> 0이기 때문에 dfs 계속 호출 -> 이런 꼴이기 때문에 continue도 잘 일어나서 맞는 것 같습니다.


 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


0

미나리

http://boj.kr/ee7f40c1f27042bba09d42a4b3af8e10
여기입니다!
번거롭게 해드려서 죄송합니다!!

0

큰돌

안녕하세요 미나리님 ㅎㅎ

image.png

 

링크가 잘못된 것 같은데 확인 부탁드립니다.

0주차 : 질문하는 방법 보시면 링크 만드는 방법 나와있어요 ~ ㅎㅎ

 

감사합니다.

진행 방법 질문드립니다!

0

22

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

53

2

2주차 개념#12 트리 순회

0

25

2

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

0

284

2

백준 서비스 종료

9

878

1

sk 하이닉스 코테 대비

0

367

2

3-G 최댓값 질문

0

50

1

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

0

83

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

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

0

66

2

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

0

169

2

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

0

69

2

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

0

64

2

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

0

51

2

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

0

68

2

함수별 시간복잡도

0

73

2

3-h 질문입니다.

0

49

1

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

0

53

2

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

0

76

2

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

91

2

5-Q 질문

0

64

2