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

김승호님의 프로필 이미지
김승호

작성한 질문수

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

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

2-E 풀이 질문있습니다

해결된 질문

작성

·

195

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

http://boj.kr/f07cde0329cb43428b1b40bb4960eb2f
위와 같이 풀이를 했는데 반례를 도저히 모르겠어서 질문남깁니다.

답변 1

1

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

안녕하세요 승호님 ㅎㅎ

코드에서 틀린 부분은 다음과 같습니다.

string go(int n ,int y , int x) {
	if (n == 1) {
		return to_string(adj[y][x]);
	}
	string temp;

지역변수 string은 초기화를 반드시 해주어야 합니다. string temp =""; 이런식으로 해주셔야 합니다.

 

bool judgment(string s) {
	char c = s[0];
	for (int i = 1;i < 4;i++) {
		if (c != s[i])
			return false;
	}
	return true;
}

그리고 4개까지 체크를 해서는 안됩니다. c는 4개 이상의 문자를 가질 수 있습니다.

    if (judgment(y, x, n)) {
        return to_string(adj[y][x]);
    }

이렇게 하고

bool judgment(int y, int x, int n) {
    int firstValue = adj[y][x];
    for (int i = y; i < y + n; i++) {
        for (int j = x; j < x + n; j++) {
            if (adj[i][j] != firstValue)
                return false;
        }
    }
    return true;
}

이렇게 하는 식의 코드가 필요합니다.

 

 

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

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

감사합니다.

강사 큰돌 올림.

 

김승호님의 프로필 이미지
김승호
질문자

와 단순히 처음 4개의 Z로직만 잘 통과하면 이후에는 문제가 생기지 않을 줄 알고 for을 4개만 돌렸었는데 '('가 더 추가하는 등의 문제가 발생하는 군요. 좋은 답변 감사드립니다 큰돌님!!

김승호님의 프로필 이미지
김승호

작성한 질문수

질문하기