3-O 시간복잡도
안녕하세요 큰돌님!
해당 문제의 시간 복잡도 관련된 질문이 있어서 여쭤봅니다.
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점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
5-B
0
16
2
4 - A
0
33
2
코딩살구클럽 입장이 안됩니다
0
82
2
4-F 경우의 수 질문입니다.
0
35
2
코딩살구클럽 가입이 안됩니다.
0
85
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
63
1
교안 158페이지 문의드립니다
0
47
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
83
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
74
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





