Search in Rotated Sorted Array

2025. 1. 9. 11:07·PS/LeetCode
반응형

문제

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

입력

1 <= nums.length <= 5000
-10^4 <= nums[i] <= 10^4
All values of nums are unique.
nums is an ascending array that is possibly rotated.
-10^4 <= target <= 10^4


// 입력 예제

Example 1:

Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4
Example 2:

Input: nums = [4,5,6,7,0,1,2], target = 3
Output: -1
Example 3:

Input: nums = [1], target = 0
Output: -1

결과

ans: Int = target이 위치한 인덱스, 먄약 없다면 -1

해석

이전 문제와 비슷한 이분탐색 문제지만 오름차순의 배열이 회전되어 있어
한번 더 조건을 걸어줘야한다.

 

그 조건은 이분탐색의 필수적인 조건인 정렬 여부, 즉 mid를 중심으로 정렬이 올바르게
되어있는 구간인가 아닌가를  판별

 

또한 mid를 통해 찾을 것이기 때문에, while문의 조건이 < 가 아닌 <= 된다.

코드

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

        var start = 0
        var end = n-1

        while start <= end {
            let mid = (start + end) / 2

            if nums[mid] == target { // 찾음
                return mid 
            }

            if nums[start] <= nums[mid]{ // mid까지 오름차순
                if nums[start] <= target && target < nums[mid] { // 왼쪽 범위에 있을 때  
                    end = mid - 1 
                } else {
                    start = mid + 1 
                }
            } else {
                if nums[mid] < target && target <= nums[end] { // end 까지 오름 차순 
                    start = mid + 1
                } else {
                    end = mid - 1
                }
            }
        }
        return -1
    }
}

 

반응형

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

Container With Most Water  (0) 2025.01.12
3Sum  (0) 2025.01.12
Find Minimum in Rotated Sorted Array  (0) 2025.01.08
Maximum Product Subarray  (0) 2025.01.08
Maximum Subarray  (1) 2025.01.05
'PS/LeetCode' 카테고리의 다른 글
  • Container With Most Water
  • 3Sum
  • Find Minimum in Rotated Sorted Array
  • Maximum Product 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)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바