inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

맞왜틀팁 : 반례를 생각하는 방법 | 2 - C 보완설명

2-C 왜 틀렸을까요..?

해결된 질문

289

박승한

작성한 질문수 7

0

http://boj.kr/4473182f754a49919a49607d9fc3711c

 

2-C 문제 왜 틀렸을까요 ㅠㅠ

 

비가 안 오는 부분도 고려하였고 나름 디버깅도 찍어 보았습니다..

 

맞왜틀팁도 보았는데...

c++ 코딩-테스트

답변 1

1

큰돌

안녕하세요 승한님 ㅎㅎ

코드 잘 짜셨네요. ㅎㅎ

 

다만, 1가지부분을 틀리셨습니다.

visited를 104 * 104 로 선언하셨다면

    for(depth=0; depth<101; depth++){
        res = 0;
        fill(&visited[0][0], &visited[0][0]+104*104, 0);

초기화도 해당 배열 전체로 해주셔야 합니다.

해당 부분은 교안내의 다음부분을 참고해주세요.

왜 fill()로 전체초기화를 해야할까? 

 

그리고 조금은 보완해야 할 부분이 있는데요.

1.data라는 변수명은 안 써야 합니다. bits/std.. 로 include하게 되면 모든 라이브러리를 import하는 것이고 그 중 일부 라이브러리에서 data변수명을 전역으로 쓰기 때문에해당 변수명 자체를 못 씁니다. 실제로 수정된 코드에서 a가 아니라 다시 data로 바꿔서 제출시 이렇게 뜨면서 컴파일러에러가 뜨게 됩니다 .

image

 

2.x, y 가 아니라 y, x가 좋습니다. 다만 이 문제의 경우 n * n 와서 상관은 없지만 y, x로 하는 습관을 기르는게 좋습니다.

교안내의 "2차원배열과 탐색을 빠르게 하는 팁"을 참고 부탁드립니다.

 

수정된 전체코드

#include <bits/stdc++.h>
using namespace std;

int a[104][104] = {0,}, visited[104][104] = {0,};

int dx[4] = {0,1,0,-1};
int dy[4] = {1,0,-1,0};

int cnt, res, max_v;
int depth;


void dfs(int x, int y){
    visited[x][y] = 1;
    for(int i=0; i<4; i++){
        int move_x = x + dx[i];
        int move_y = y + dy[i];
        if(move_x < 0 || move_x >= cnt || move_y < 0 || move_y >= cnt) continue;
        if(visited[move_x][move_y]) continue;
        if(a[move_x][move_y] <= depth) continue;
        dfs(move_x,move_y);
    }
}

int main(){
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    
    cin >> cnt;
    
    for(int i=0; i<cnt; i++){
        for(int j=0; j<cnt; j++){
            cin >> a[i][j];
        }
    }
    
    for(depth=0; depth<101; depth++){
        res = 0;
        fill(&visited[0][0], &visited[0][0]+104*104, 0);
        for(int i=0; i<cnt; i++){
            for(int j=0; j<cnt; j++){
                if(visited[i][j]) continue;
                if(a[i][j] <= depth) continue;
                dfs(i,j);
                res += 1;
            }
        }
        if(res > max_v){
            max_v = res;
        }
    }
    
    
    cout << max_v;
    
    return 0;
    
}

 

depth부분 전역변수 부분이나 전체적인 로직자체는 잘 짜셨습니다.

 

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

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

감사합니다.

강사 큰돌 올림.


4 - A

0

8

1

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

0

47

2

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

0

30

2

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

0

63

2

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

0

52

1

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

0

43

2

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

0

104

1

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

0

44

1

진행 방법 질문드립니다!

0

78

2

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

0

63

2

2주차 개념#12 트리 순회

0

32

2

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

0

307

2

백준 서비스 종료

9

943

1

sk 하이닉스 코테 대비

0

382

2

3-G 최댓값 질문

0

53

1

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

0

84

2

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

0

63

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

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

0

68

2

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

0

179

2

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

0

71

2

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

0

65

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

52

2