inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

2-E 질문

364

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

감사합니다.

강사 큰돌 올림.

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2