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

요가인님의 프로필 이미지
요가인

작성한 질문수

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

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

2-E 재귀함수 범위관련 질문 있습니다

해결된 질문

작성

·

254

1

안녕허세요 강사님

강사님 풀이 과정을 3번 이상 듣고 코드를 여러번 봤는데도 잘 이해가 안가는 부분이 있어서 질문드립니다!

 

강사님 코드기준(해설집) 11번째줄과 12번째줄에

for(int i = y; i < y + size; i++){
        for(int j = x; j < x + size; j++){

이렇게 i 와 j 의 범위를 나누셨는데

왜 y가 0 일때 모든 x 값 비교하고 재귀하고

이런식으로 만든 이유가 궁금해서 질문합니다.

 

왼쪽 위, 오른쪽 위, 왼쪽 아래, 오른쪽 아래 이렇게 한 묶음으로 검사를 하고 그 값을 return 하고 해야 맞지 않나요 ?

제가 풀었던 범위 나누기와 달라서 너무 헷갈려서 질문합니다.

 

 #include <iostream>
using namespace std;

// 좌상 우상 좌하 우하
const int dy[4] = { -1, -1, 0, 0 };
const int dx[4] = { -1, 0, -1, 0 };

int N;
char adj[65][65];
string ret;

string QuardTree(int y, int x, int n)
{
	string str;

	if (n == 1)
		return str += adj[y][x];

	n = n >> 1;					// n -> 2
	for (int i = 0; i < 4; i++)
	{
		int ny = y + dy[i] * n;	// 2 --> 1
		int nx = x + dx[i] * n;
		str += QuardTree(ny, nx, n);
	}

	if (str == "0000")
		str = "0";
	else if (str == "1111")
		str = "1";
	else
		str = "(" + str + ")";

	return str;
}


int main()
{
	cin >> N;

	for (int y = 1; y <= N; y++)
	{
		string temp;
		cin >> temp;
		for (int x = 1; x <= temp.size(); x++)
			adj[y][x] = temp[x - 1];
	}

	ret += QuardTree(N, N, N);

	cout << ret;
	
	return 0;
}

혹시 질문이 이해가 안가실까봐 제 코드 풀이도 올려요

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 가인님 ㅎㅎ

왼쪽 위, 오른쪽 위, 왼쪽 아래, 오른쪽 아래 이렇게 한 묶음으로 검사를 하고 그 값을 return 하고 해야 맞지 않나요 ?

>>

    for(int i = y; i < y + size; i++){
        for(int j = x; j < x + size; j++){ 
            if(b != a[i][j]){ 
                ret += '(';
                ret += quard(y, x, size / 2); 
                ret += quard(y, x + size / 2, size / 2);
                ret += quard(y + size / 2, x, size / 2);
                ret += quard(y + size / 2, x + size / 2, size / 2); 
                ret += ')';
                return ret;  

사실 제가 한 코드가 그런 의미입니다. 왼위, 오위 등을 나눠서 검사하고 해당 값을 더해서 return 하고 있습니다.

    for(int i = y; i < y + size; i++){
        for(int j = x; j < x + size; j++){ 

물론, 해당 함수마다 왼위, 오위, 오아 등의 범위를 정해서 해도 되지만 저렇게 하나의 꼭지점, 왼위를 기반으로 잡는게 더 쉽기 때문에 저렇게 한 것입니다.

그리고 가인님 코드리뷰를 좀 하자면

string QuardTree(int y, int x, int n)
{
	string str;

	if (n == 1)
		return str += adj[y][x];

str이 지역변수로 선언되었는데 이렇게 되면 str에 쓰레기값이 들어갈 수 있습니다.

string str = "";

로 할당하셔야 합니다.

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

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

감사합니다.

강사 큰돌 올림.

요가인님의 프로필 이미지
요가인

작성한 질문수

질문하기