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

욕망의햄버거님의 프로필 이미지
욕망의햄버거

작성한 질문수

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

3-O

3-O 시간복잡도

해결된 질문

작성

·

373

0

안녕하세요 큰돌님!

해당 문제의 시간 복잡도 관련된 질문이 있어서 여쭤봅니다.


3-O 번 문제에 대해서 어떤 로직을 쓸 지 고민하다가,

사다리 3개 조작, 사다리 내려가기 << 이렇게 2 가지 로직이 필요 하다고 생각했습니다.

그래서 제가 계산한 바는,
사다리 3개 조작 : 300 C 3
사다리 내려가기 : 30 * 10

이 둘의 로직이 동시에 일어나야 한다고 생각해서,
300 C 3 * (30 * 10) 라고 결론 냈습니다.


http://boj.kr/475effafef89456687b5176ac5dcf21c
(정답코드 링크)

그런데, 강의를 보니까

선생님은 300 C 3 만 언급하셧는데요. 이 부분이 이해가 되지 않습니다.

정답코드의 재귀 함수만 보더라도, 2중 for문 안에서 go()가 호출되는데, 이런 경우는 사다리 내려가기에 대한 시간복잡도가 영향을 받지 않는건가요?

// 경우의 수를 두면서 재귀.
    for(int i = here; i <= h; i++){
        for (int j = 1; j <= n; j++)
        {
            // 이미 존재하는 경우는 예외
            if(line[i][j] || line[i][j-1] || line[i][j+1]) continue;
            
            // 경우의 수 추가
            line[i][j] = 1;
            go(i, cnt + 1);
            line[i][j] = 0;
        }
        
    }

질문이 좀 길어졌네요. 정리하면 이렇습니다.

Q1. 제가 계산했던, 사다리 조작 * 사다리 내려가기 에 대한 시간 복잡도 계산은 틀렸나요? 틀렸다면 어디서 로직 오류가 있는건가요?

Q1-1. 혹시, 제가 계산했던 시간 복잡도에서,
300 C 3 + (30*10) 으로 계산해도 무방한가요?

Q2.선생님은 왜 300 C 3 이라고만 계산하셨나요?
완탐이든/백트래킹이든 재귀로 탐색(?)해야 하는 건 알겠는데, go() 함수가 호출되는 2중 for문에 대한 시간복잡도는 계산 안하셨는지 모르겠습니다.


답변 기다리고 있겠습니다!

감사합니다~!!

답변 1

0

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

안녕하세요 진살라진님 ㅎㅎ

에 진살님 말씀이 맞습니다.

사다리 3개 조작 : 300 C 3
사다리 내려가기 : 30 * 10

이 둘의 로직이 동시에 일어나야 한다고 생각해서,
300 C 3 (30 10) 라고 결론 냈습니다.

Q2.선생님은 왜 300 C 3 이라고만 계산하셨나요?
완탐이든/백트래킹이든 재귀로 탐색(?)해야 하는 건 알겠는데, go() 함수가 호출되는 2중 for문에 대한 시간복잡도는 계산 안하셨는지 모르겠습니다.

>> 가 맞습니다. 이 문제에서 중요한 시간복잡도만을 설명해서 그런데요. 보통 시간복잡도를 산정하고 그걸 기반으로 조금 더 효율적인 알고리즘을 고민할 때 "바꿀 수 있는 시간복잡도"를 중심으로 고민합니다. 여기서 사다리 내려가기 부분은 "바꿀 수 없는 시간복잡도"이기 때문에(확인해야하는 것은 무조건... 그정도 들거든요)해당 부분은 이 강의에서 말씀드리지 않고 순서와 상관있게 고르는 것이 아니라 순서 상관없이 조합으로 골라도 된다. 라는 것을 강조하기 위해 300C3만을 얘기한건데 정확히 말씀하자면 전체적인 시간복잡도는 진살님 말씀이 맞습니다.

Q1-1. 혹시, 제가 계산했던 시간 복잡도에서,
300 C 3 + (30*10) 으로 계산해도 무방한가요?

>> + 가 아니라 첨에 말씀하신 것처럼 인 300C3 * 30 * 10이 맞습니다. 고르고 >> 탐색이니까요..

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

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

감사합니다.

강사 큰돌 올림.

욕망의햄버거님의 프로필 이미지
욕망의햄버거

작성한 질문수

질문하기