Order Statistics
- The ith order statistic in a set of n elements is the ith smallest element
- The minimum is thus the 1st order statistic
- The maximum is the nth order statistic
- The median is
- the (n+1)/2 order statistic, if n is odd
- lower median i=n/2, upper median i=(n/2)+1, if n is even
Finding Min and Max Simultaneously
- Input : n numbers
- Output : min and max
- n-1 comparisons for min, n-1 comparisons for max : total 2n-2 comparisons
- Can we do better?
- Don’t compare each element to min and max separately, but process elements in pairs - compare the elements of a pair to each other.
- Then compare the larger element to the current max so far, and compare the smaller element to the current min so far
- Only 3 comparisons for every 2 elements
- For initial min and max :
- If n is even, compare the first two elements and set the larger to max and the smaller to min. Then process the rest in pairs.
: 1 initial comparison and 3(n-2)/2 more comparisons = 3n/2 – 2data:image/s3,"s3://crabby-images/0d24d/0d24d9889a54747e820c0fc926ecfb721ded1492" alt=""
- If n is odd, set both min and max to the first element. Then process the rest in pairs.
: If n is odd, 3(n-1)/2 comparisonsdata:image/s3,"s3://crabby-images/13647/136477c69347a84924ee91604b0ee2e49f085cd0" alt=""
The Selection Problem
- A more interesting problem is selection: finding the ith smallest element of a set
- Input: A set A of n (distinct) elements and a number i, with 1 ≤ i ≤ n.
- Output: The element x in A that is larger than exactly i-1 other elements of A → ith element
data:image/s3,"s3://crabby-images/9317f/9317ffa0e6a37817b05dab8aff9989a3e45718c3" alt=""
- We will study two algorithms:
- A practical(실용적인) randomized algorithm with Θ(n) expected(avg) running time
- A cool algorithm of theoretical interest only with Θ(n) worst-case running time
Randomized Selection
- Key idea: use partition() from quicksort
- But, only need to examine one subarray
- This saving shows up in running time: Θ(n) → 양쪽 다 필요 x
- Partition the array A[p..r] into two (possibly empty) subarrays A[p..q-1] and A[q+1..r]
- If i=k, return A[q]
- If i < k, find ith in the subarray A[p..q-1]
- If i > k, find (i-k)th smallest element in the subarray A[q+1..r]
data:image/s3,"s3://crabby-images/37ec4/37ec48d933c26aaaab7bbc5aa650aa61b8a9b1dc" alt=""
Exampledata:image/s3,"s3://crabby-images/165aa/165aa4af14c797301af754e74473a940f9f5ede6" alt=""
Codedata:image/s3,"s3://crabby-images/f85f0/f85f0b43583e1ac175f9ae50305204c6b26283d2" alt=""
Intuition for analysis
- ( All our analyses today assume that all elements are distinct )
data:image/s3,"s3://crabby-images/b7a3d/b7a3d2ee09a6c47363619731a89762ba3255a08a" alt=""
data:image/s3,"s3://crabby-images/33499/334992cae1481b89ad3a292538871c619ca974f2" alt=""
data:image/s3,"s3://crabby-images/e40b4/e40b4fd1c2ae51649f87a1591b02293849cf305e" alt=""
data:image/s3,"s3://crabby-images/f3185/f3185a07e3317cb94bcef0cd23dd9c611496969a" alt=""
Worst-case Linear-Time Selection
- Randomized algorithm works well in practice.
But in worst case its time complexity is O(n2)
- What follows is a worst-case linear time algorithm, really of theoretical interest only
- Basic idea:
- Generate a good partitioning element
- Call this element x
Pesudo-codedata:image/s3,"s3://crabby-images/70a95/70a956ef8f7289a44e5091712f6da487c52d2bd0" alt=""
Initiallydata:image/s3,"s3://crabby-images/9adce/9adce880f6e91cbb2527942807203d06b3e83ef7" alt=""
Step 2data:image/s3,"s3://crabby-images/637a6/637a63edb64ecf75d2d2f98e40afc9ce29d7a017" alt=""
data:image/s3,"s3://crabby-images/0ee87/0ee879fcb8b36b2284b19c00c4de605dd4dec2bb" alt=""
Step 3data:image/s3,"s3://crabby-images/52129/52129a84689fe5775b8e461eaa889f28bf6bd80a" alt=""
Around the pivotdata:image/s3,"s3://crabby-images/981f6/981f6c38fa9647b511511f05580ba569abe59fec" alt=""
data:image/s3,"s3://crabby-images/d123d/d123d34d8b5093d74e4970f2896b04cb09f01cff" alt=""
data:image/s3,"s3://crabby-images/bac2f/bac2f8d420e333e472a1aa5dd603a909526d4b80" alt=""
Analysisdata:image/s3,"s3://crabby-images/d1d9d/d1d9de382e513e764cb2a938065215d9517afa65" alt=""
data:image/s3,"s3://crabby-images/c5854/c58540a705c3a314b3b94d68f8e53a23aa3ea872" alt=""
Exercise in Class
1. data:image/s3,"s3://crabby-images/1c467/1c467f8ebf47b6b2a6ce917dfdffd3bda4f2c6c7" alt=""
data:image/s3,"s3://crabby-images/943e7/943e72cd87b4ce8adb0849ebd1af20d5442456e3" alt=""
data:image/s3,"s3://crabby-images/392f0/392f09e83766ffcd0888b1a0edbce934ca6354b9" alt=""
A. 6data:image/s3,"s3://crabby-images/a2dbf/a2dbfee1e3a3bc27c88c3eea6b714f261eb2cc05" alt=""
HGU 전산전자공학부 용환기 교수님의 23-1 알고리듬 분석 수업을 듣고 작성한 포스트이며, 첨부한 모든 사진은 교수님 수업 PPT의 사진 원본에 필기를 한 수정본입니다.