File tree Expand file tree Collapse file tree 2 files changed +67
-0
lines changed
find-minimum-in-rotated-sorted-array Expand file tree Collapse file tree 2 files changed +67
-0
lines changed Original file line number Diff line number Diff line change 1+ /**
2+ * 정렬된 배열에서 최소값 찾기
3+ * 알고리즘 복잡도
4+ * - 시간 복잡도: O(logn)
5+ * - 공간 복잡도: O(1)
6+ * @param nums
7+ */
8+ function findMin ( nums : number [ ] ) : number {
9+ // 풀이 1 - sort() 사용
10+ // 시간 복잡도: O(nlogn) / 공간 복잡도: O(1)
11+ // nums.sort((a, b) => a - b)
12+ // return nums[0]
13+
14+ // 풀이 2 - 배열이 정렬되어 있음을 활용한 풀이
15+ // 시간 복잡도: O(n) / 공간 복잡도: O(1)
16+ // let min = nums[0];
17+ // for(let i = 1; i < nums.length; i++) {
18+ // console.log(nums[i])
19+ // min = Math.min(nums[i], min)
20+ // }
21+ // return min
22+
23+ // 이분 탐색법 활용
24+ // 절반씩 잘라서 nums[n-1] > nums[n] 의 지점을 찾는다
25+ let low = 1 ;
26+ let high = nums . length - 1 ;
27+ while ( low <= high ) {
28+ let mid = Math . floor ( ( low + high ) / 2 ) ;
29+ if ( nums [ mid - 1 ] > nums [ mid ] ) {
30+ return nums [ mid ] ;
31+ }
32+ if ( nums [ 0 ] < nums [ mid ] ) {
33+ low = mid + 1 ;
34+ } else {
35+ high = mid - 1 ;
36+ }
37+ }
38+ return nums [ 0 ]
39+ }
Original file line number Diff line number Diff line change 1+ /**
2+ * Definition for singly-linked list.
3+ * class ListNode {
4+ * val: number
5+ * next: ListNode | null
6+ * constructor(val?: number, next?: ListNode | null) {
7+ * this.val = (val===undefined ? 0 : val)
8+ * this.next = (next===undefined ? null : next)
9+ * }
10+ * }
11+ */
12+ /**
13+ * 순환되는 링크드 리스트 찾기
14+ * 알고리즘 복잡도
15+ * - 시간 복잡도: O(n)
16+ * - 공간 복잡도: O(n)
17+ * @param head
18+ */
19+ function hasCycle ( head : ListNode | null ) : boolean {
20+ let set = new Set ( ) ;
21+ while ( head !== null ) {
22+ // set에 이미 존재하는지 확인
23+ if ( set . has ( head ) ) return true
24+ set . add ( head )
25+ head = head . next
26+ }
27+ return false
28+ }
You can’t perform that action at this time.
0 commit comments