시간복잡도에 관해서!
302
제이슨
작성한 질문수 2
0
안녕하세요! 선생님 덕분에 많이 배우고 있습니다.
질문이 굉장히 많은데 모든 질문에 답변해주셔서 매우 놀라고 기뻤습니다..!
const solution = function (arr, m) {
let cnt = 0;
for (let lt = 0; lt < arr.length; lt++) {
let sum = arr[lt],
rt = lt;
while (sum <= m) {
cnt++;
sum += arr[++rt];
}
}
return cnt;
}
console.log(solution([1, 3, 1, 2, 3], 5)); // 10
console.log(solution([1, 1, 1, 1], 5)); // 10
console.log(solution([10, 5, 2, 6], 100)); // 10
강의 듣기 전에 풀어본 것인데 혹시 반례가 있을까요?
그리고 제가 생각했을 때 이 코드의 반복문 실행 횟수가 가장 많아지는 경우는 입력된 수열이 [1, 1, 1, 1] 처럼 모든 요소를 다 더해도 m을 넘어가지 않는 경우에
for문의 lt가 0 일 때 :
while문 반복 실행 횟수 4
(sum = 1일때, 2일때, 3일때, 4일때)
lt가 1일 때:
while문 반복 횟수 3
(sum = 1, 2, 3)
lt가 2일 때:
while문 반복 횟수 2
(sum = 1, 2)
lt가 3일 때:
while문 반복 횟수 1
(sum = 1)
이렇게 되니까
입력된 수열의 길이가 n이라 하면
최악에 경우에 실행 횟수는 n + n - 1 + n - 2 + ... + 1
n + n - 1 + n - 2 + ... + 1 (lt = 0일떄 while실행횟수 ~ 마지막)
1 + 2 + 3 + ... + n (lt = arr.length-1일때 while ~ 처음)
-------------------------
n * (n + 1)
이니까 총 실행 횟수는 (n^2 + n) / 2 여기서 최고차항 뺴고 다 없애고 계수도 없애면 n^2이니까 시간복잡도는 O(n^2) 이라고 생각했는데 제가 시간복잡도를 맞게 구한걸까요?
반면에 선생님의 코드는 가장 반복 횟수가 많아지는 경우가
제가 고민해봤을 떄 입력된 수열의 길이가 n일때, n -1 번째까지는 다 더해도 m을 안 넘는데 마지막꺼 더했을 때 m을 넘어가는 경우일 것 같은데.. 잘 모르겠어요. 이 경우가 맞을까요?
그럼 이 경우는 for문의 rt가 0에서 마지막 요소까지 쭉 가다가 (실행횟수 = 요소의 갯수 = n번)
마지막 요소에서 와일문이 rt = 0부터 마지막 요소까지 실행되니까
총 2n번 실행되는게 최대 반복 횟수일거같은데
제가 생각한 것이 맞는지 궁금합니다.
그리고 선생님처럼 이렇게 푸는 방법은 솔직히 제 머리론 죽었다 꺠어나도 못떠올릴거같은데 문제를 많이 풀다보면 머리가 좋아질까요..?
답변 1
0
안녕하세요^^
위에 제이슨님 코드는 O(N^2)의 시간복잡도를 갖습니다.
알고리즘을 처음부터 잘 하는 사람은 없습니다. 문제를 많이 풀고 경험하다 보면 실력자가 되어 있을 겁니다.
화이팅하세요^^
continue를 사용하는 이유
0
80
2
정렬 가능 여부 판단하기
0
65
2
알고리즘 학습법 관련해서 질문드립니다.
0
86
1
코드 리뷰 부탁드립니다!
0
90
1
indexOf를 사용해서 풀어보았습니다 !!
0
69
1
저는 이런식으로 구현 해보았습니다 !!
0
64
1
12,13,14 강의 소리만 나오고 검은 화면입니다
0
101
3
반복문 최소화하고 indexOf 사용해서 풀어봤습니다
0
63
1
영상 보기 전에 직접 풀어봤습니다.
0
74
1
섹션1의 17번문제 이 풀이로 풀어도 될까요?
0
136
2
정규표현식으로 처리해도 상관없나요 ?
0
120
2
3칸씩 건너뛸 수 있을 경우
0
126
2
강의에 대해 질문있습니다.
0
136
2
Object와 Set을 이용해 풀어봤습니다.
0
117
2
이렇게 해도 되나요?
0
102
2
선생님 중복 단어나 중복관련 문제들은 set을 이용하면 좋을것 같습니다.
0
145
2
이렇게 풀어도 괜찮을까요?
0
138
1
이렇게 풀어도 괜찮을까요?
0
112
1
모든 아나그램 찾기에서 시간복잡도
0
98
1
코드리뷰 부탁드립니다.
0
130
1
for loop 탈출은 return 문으로 해도 되지 않나요?
0
133
1
투포인트알고리즘으로 풀어봤습니다.
0
142
0
코드 리뷰 부탁드립니다.
0
120
1
코드 맞게 작성한 거 아닌가여??
0
146
1





