inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-E와 분할정복(Divide & Conquer)

2-E 질문

355

kkim360

작성한 질문수 31

0

선생님 선생님 코드도 봤는데 제가 dfs bfs에 너무 심취해서 너무 힘들게 코드를 짠것 같습니다 ㅎㅎ. 제 코드 한번만 봐주시면 정말 감사하겠습니다.

제 코드 질문을 comment로 해두었습니다.

제 질문은 dfs함수에 설정한 값을 go함수에 어떻게 적용할 수 있는지가 질문입니다!

http://boj.kr/3ca895726f3c47e09671343422cade85

선생님 코드와 제 코드가 조금은 비슷해서 실력이 늘고있는거 같아 기분이 좋습니다. 수업 잘 듣고 있습니다 항상 감사합니다!

 

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 360님 ㅎㅎ

이 dfs가 하는 역할은 해당 영역이 같은지 안같은지만 확인하면 되는거 아닌가요?

void dfs(int y,int x,int n){
	visited[y][x]=1;
	flag =0;
	for(int i=0;i<n;i++){
		int ny= n+dy[i];
		int nx= n+dx[i];
		if(ny<y||ny>=y+n||nx<x||nx>=x+n)continue;
		if(visited[ny][nx])continue;
		//제가 생각했던것은
		//다른값을 마주하였을때 전역변수에 flag가 1이 되고
		//그 flag가 go함수까지 영향을 끼치는것이었습니다
		if(arr[y][x]!=arr[ny][nx]){
			flag = 1;
			return;
		}
		dfs(ny,nx,n);
	}
	return;
}

 

먼저 이부분은 2중 for문으로 해도 되는데 굳이 dfs로 재귀적으로 구현할 필요는 없습니다.

함수호출은 cost다 라고 꼭 생각하셔야됩니다.

그러나!

however!

nevertheless!

dfs로 구현해야 한다면.

4각영역을 정하고 해당 4각영역안에서 재귀적으로 호출되며 모든 영역들을 탐색해가며 같은 것을 탐색해야 하는 로직이 필요한데요. 그리고 같지 않다면 flag를 1로 바꿔야 하구요.

 

이렇게 구축을 하시면 됩니다.

#include <bits/stdc++.h>
using namespace std;
 
int dy[]={-1,0,1,0}, dx[]={0,1,0,-1};  
int a[4][4], visited[70][70], flag;
void dfs(int y,int x,int sy, int sx, int ey, int ex){ 
	visited[y][x]=1;
	int s = a[y][x];  
	for(int i=0; i < 4;i++){
		int ny= y + dy[i];
		int nx= x + dx[i];
		if(ny < sy || ny >= ey) continue;
		if(nx < sx || nx >= ex) continue; 
		if(visited[ny][nx])continue; 
		if(s != a[ny][nx]){
			flag = 1;
			return;
		}
		dfs(ny,nx,sy, sx, ey, ex);
	}
	return;
}  
int main(){
	a[1][2] = 1;
	dfs(0, 0, 0, 0, 4, 4); 
	cout << flag << "\n";
	return 0;
}

 

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

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

감사합니다.

강사 큰돌 올림.

5-B

0

15

2

4 - A

0

33

2

코딩살구클럽 입장이 안됩니다

0

82

2

4-F 경우의 수 질문입니다.

0

35

2

코딩살구클럽 가입이 안됩니다.

0

85

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

63

1

교안 158페이지 문의드립니다

0

46

2

코딩살구클럽 관련 건의사항

0

119

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

45

1

진행 방법 질문드립니다!

0

83

2

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

0

64

2

2주차 개념#12 트리 순회

0

33

2

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

0

318

2

백준 서비스 종료

9

953

1

sk 하이닉스 코테 대비

0

388

2

3-G 최댓값 질문

0

54

1

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

0

84

2

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

0

66

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

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

0

69

2

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

0

186

2

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

0

74

2

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

0

66

2