[LeetCode#75] Sort Colors

2024. 10. 1. 00:23·Algorithm/문제풀이

 

❒ Description


날짜 2024.09.30 (월)
레벨 Medium
제목 Sort Colors
링크 https://leetcode.com/problems/sort-colors/description/?envType=problem-list-v2&envId=sorting
알고리즘 Dutch National Flag, Insertion-sort
시간 복잡도 O(N)

 

 

 

 

 

❒ 문제 및 로직 분석


이번 문제는 in-place 알고리즘을 사용해서 풀이해야 하는데, 그 중에서는 시간복잡도가 O(N)인 

네덜란드 국기 (Dutch National Flag) 알고리즘을 구현해야 하는 문제이다. 물론 삽입 정렬로도

풀이가 가능하지만 삽입정렬은 input의 크기가 커질수록 성능이 저하되기 때문에 여기서는 제외다.

 

 

 

 

 

❒ Solution


1. 삽입 정렬

public void sortColors(int[] nums) {
    for (int i = 1; i < nums.length; i++) {
        int target = nums[i];
        int beforeIdx = i - 1;
        while (beforeIdx >=0 && nums[beforeIdx] > target) {
            nums[beforeIdx + 1] = nums[beforeIdx];
            nums[beforeIdx] = target;
            beforeIdx --;
        }
    }
}

 

 

2. DNF 알고리즘

public void sortColors(int[] nums) {
    int low = 0;
    int mid = 0;
    int high = nums.length - 1;
    
    while (mid <= high) {
      if (nums[mid] == 2) {
          swap(nums, mid, high);
          high --;
      } else if (nums[mid] == 1) {
          mid ++;
      } else if (nums[mid] == 0) {
          swap(nusm, low, mid);
          low ++;
          mid ++;
      }
    }
}

private void swap(int[] nums, int v1, int v2) {
    int tempt = nums[v2];
    nums[v2] = nums[v1];
    nums[v1] = temp;
}

 

 

 

 

 

 


'Algorithm > 문제풀이' 카테고리의 다른 글

[LeetCode#74] Search a 2D Matrix  (0) 2024.10.02
[LeetCode#33] Search in Rotated Sorted Array  (0) 2024.10.01
[LeetCode#242] Valid Anagram  (0) 2024.09.29
[LeetCode#179] Largest Number  (0) 2024.09.29
[LeetCode#147] Insertion Sort List  (0) 2024.09.28
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#74] Search a 2D Matrix
  • [LeetCode#33] Search in Rotated Sorted Array
  • [LeetCode#242] Valid Anagram
  • [LeetCode#179] Largest Number
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (173)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (4)
        • Java (3)
        • Kotlin (1)
      • Back-End (13)
        • SpringBoot (1)
        • Trouble Shooting (0)
        • Setup & Configuration (1)
        • SQL (3)
        • Redis (8)
      • Architecture (6)
        • Multi Module (1)
        • DDD (5)
      • CS (30)
        • Data Structure (6)
        • Operating System (0)
        • Network (12)
        • Database (10)
        • Design Pattern (2)
      • Algorithm (78)
        • 내용 정리 (18)
        • 문제풀이 (60)
      • DevOps (6)
        • AWS (5)
        • Git (1)
      • Front-End (1)
        • Trouble Shooting (1)
      • Project (6)
        • 페이스콕 (6)
      • Book (7)
        • 이벤트 기반 마이크로서비스 구축 (6)
        • 친절한 SQL 튜닝 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    sliding-window
    greedy
    binarysearch
    Two-Pointer
    오블완
    부분단조성
    Back-Tracking
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[LeetCode#75] Sort Colors
상단으로

티스토리툴바