Find Minimum in Rotated Sorted Array

2025. 1. 8. 23:16·PS/LeetCode
반응형

문제

https://leetcode.com/problems/find-minimum-in-rotated-sorted-array/description/

입력

n == nums.length
1 <= n <= 5000
-5000 <= nums[i] <= 5000

결과

ans: Int = 배열의 최솟값

해석

정렬이 됐지만 회전까지 들어가 있어 문제의 본질을 파악하는데 함정을 파뒀다.

하지만 시간 복잡도 제약이 O(logn)인 것을 보고 이분 탐색이라는 것을 눈치 챌 수 있었다.

 

mid를 기준으로 right 값이 큰지 작은 지를 판단하여

크다면 오른쪽 부분은 버려주는 형식으로 진행

코드

class Solution {
    func findMin(_ nums: [Int]) -> Int {
        let n = nums.count

        if n ==  1{
            return nums[0]
        }

        var left = 0
        var right = n - 1

        var ans: Int = Int.max
        while left < right {
            let mid = (left+right) / 2

            if nums[mid] <= nums[right] {
                right = mid
            } else {
                left = mid + 1
            }
        }

        return nums[left]
    }
}

 

자주 쓰는 이분 탐색 코드

  하한 ( Lower Bound )  상한 (Upper Bound)
의미 주어진 값 이상인 첫 번째 위치 주어진 값보다 큰 첫 번째 위치
결과 >= (같거나 큰 값의 위치) > (보다 큰 값의 위치)
특징 배열에서 특정 값이 존재하지 않더라도,
그 값보다 큰 첫 번째 위치를 반환
특정 값이 배열에 여러 개 존재하더라도
마지막 값 이후의 위치를 반환

 

 

func lowerBound(_ arr: [Int], _ x: Int) -> Int {
  var start = 0
  var end = arr.count-1
  
  while (start < end) {
    let mid = (start + end) / 2
    if arr[mid] >= x { end = mid }
    else { start = mid + 1}
  }

  return end
}

func upperBound(_ arr: [Int], _ x: Int) -> Int {
  var start = 0
  var end = arr.count-1
  
  while (start < end) {
    let mid = (start + end) / 2
    if arr[mid] > x { end = mid }
    else { start = mid + 1}
  }

  return end
}
반응형

'PS > LeetCode' 카테고리의 다른 글

3Sum  (0) 2025.01.12
Search in Rotated Sorted Array  (0) 2025.01.09
Maximum Product Subarray  (0) 2025.01.08
Maximum Subarray  (1) 2025.01.05
Product of Array Except Self  (0) 2025.01.05
'PS/LeetCode' 카테고리의 다른 글
  • 3Sum
  • Search in Rotated Sorted Array
  • Maximum Product Subarray
  • Maximum Subarray
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (329) N
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (11) N
        • 이론 (10) N
        • MCP (1)
        • LangGraph (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Swift
    protocol
    백준
    GIT
    AVFoundation
    투포인터
    dp
    property
    dfs
    concurrency
    프로그래머스
    CS
    boostcamp
    SwiftUI
    lifecycle
    Tuist
    dispatch
    IOS
    Spring
    UIKit
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
Find Minimum in Rotated Sorted Array
상단으로

티스토리툴바