inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

4-H

4-H

41

ms4803gs

작성한 질문수 5

0

안녕하세요 제가 이 문제를 풀었을 떄 큰돌님과 다른 부분이 있어서, 효율성 측면에서 많이 떨어지는 코드인지 궁금해서 질문 드립니다!

http://boj.kr/f1e7e2f7cf8c4ecfb4961534aebacdf4

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

거의 다 괜찮은데 이부분, 방문 여부와 상관없이 DFS 콜이 비효율적인 것 같습니다.

스크린샷 2025-11-25 오전 6.49.22.png.webp

바로 요부분이죠 ㅎㅎ

사실은 방의 크기가 50이하이기 때문에 -> 2500이 최대범위라 시간복잡도상 그렇게 큰 차이는 없지만 만약 최대범위가 커진다면 반드시 고쳐야 하는 코드이기도 합니다.

이부분을 이렇게 바꿔보시겠어요?

void DFS(int y, int x){
    visited[y][x] = 1;
    cnt++;
    for(int i = 0; i < 4; i++){
        if ((field[y][x] & (1 << i)) == 0) {
            int ny = y, nx = x;
            if (i == 0) nx = x - 1;        // 서
            else if (i == 1) ny = y - 1;   // 북
            else if (i == 2) nx = x + 1;   // 동
            else if (i == 3) ny = y + 1;   // 남

            if (ny >= 0 && ny < m && nx >= 0 && nx < n && !visited[ny][nx]) {
                DFS(ny, nx);
            }
        }
    }
}

int go(){
    memset(visited, 0, sizeof(visited));
    int answer = 0;
    for(int i = 0; i < m; i++){
        for(int j = 0; j < n; j++){
            if (!visited[i][j]) {      // 이 조건 해야되용
                cnt = 0;
                DFS(i, j);
                answer = max(answer, cnt);
            }
        }
    }
    return answer;
}

 


 

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

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

감사합니다.

강사 큰돌 올림.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. ms4803gs님.

효율성 측면에서 작성하신 코드와 큰돌님의 코드가 어떤 차이를 보이는지 궁금하시다면, 몇 가지 주요 관점을 고려해 볼 수 있습니다.

코드 효율성 비교 방법

  1. 시간 복잡도: 코드의 핵심 루프가 얼마나 자주 돌아가며, 주어진 입력 크기에 대해 얼마나 효율적으로 처리되는지 확인합니다. 큰돌님의 코드와 비교하여 반복문이나 조건문이 더 많이 사용되고 있는지 확인해 보세요.

  2. 공간 복잡도: 사용하신 자료 구조가 메모리 효율을 잘 고려하고 있는지, 불필요한 메모리 사용이 없는지 따져 보세요.

  3. 사용된 알고리즘: 동일한 문제를 풀 때, 큰돌님과 다른 알고리즘적 접근을 하셨다면, 그 알고리즘이 문제에 대해 최적화된 해법인지 검토합니다.

이와 관련한 유사 질문 및 답변

이런 내용을 바탕으로 자신의 코드와 큰돌님 코드를 비교 검토해 보시면, 효율성 측면에서 어떤 개선점이 있는지 확인하실 수 있을 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

코딩살구클럽 승인

0

11

2

3-D 관련 질문

0

23

2

코살구 회원가입 문의

0

29

2

코살구 로그인 문제

0

51

2

3-A 문제 풀이 관련 질문

0

47

3

2-O 질문 있습니다

0

35

2

2-T 문제에 관한 질문

0

36

2

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

0

52

2

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

0

63

2

코딩살구클럽 로그인문제

0

72

3

코딩 살구 클럽 로그인 문제

0

76

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

75

1

살구클럽 아이디 없음 문제

0

74

1

1-O 코딩살구클럽 채점관련 질문

0

58

2

히든 테스트 케이스가 사라졌습니다

0

55

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

73

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

66

2

1-H 문제 채점하기 오류

0

58

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

52

2

살구 클럽 채점 관련 문의

0

62

2

코딩 살구 클럽 실전 세션

0

58

2

코딩살구클럽 채점 관련 질문

0

50

2

코딩살구클럽 컴파일에러

0

79

2