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

kkim360님의 프로필 이미지
kkim360

작성한 질문수

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

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

2-E 질문

작성

·

309

0

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

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

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

http://boj.kr/3ca895726f3c47e09671343422cade85

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

 

답변 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점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

kkim360님의 프로필 이미지
kkim360

작성한 질문수

질문하기