What is exactly meant by "k" in this lecture slide of Quick Select?
1
There are 1 best solutions below
Related Questions in ALGORITHM
- lua udp not working between computers
- Guitar Hero-like Timing Mechanic
- Call download lua script in app
- Erlang spawning large amounts of C processes
- does redis cluster support transactions ?
- I am writing an IVR using Lua and want to run xml script in between
- How to read a Bunch of files in a directory in lua
- How to pause a Lua script?
- lua 5.2.3 source lstring.c function luaS_resize
- Torch Lua: Why is my gradient descent not optimizing the error?
Related Questions in SELECT
- lua udp not working between computers
- Guitar Hero-like Timing Mechanic
- Call download lua script in app
- Erlang spawning large amounts of C processes
- does redis cluster support transactions ?
- I am writing an IVR using Lua and want to run xml script in between
- How to read a Bunch of files in a directory in lua
- How to pause a Lua script?
- lua 5.2.3 source lstring.c function luaS_resize
- Torch Lua: Why is my gradient descent not optimizing the error?
Related Questions in QUICKSELECT
- lua udp not working between computers
- Guitar Hero-like Timing Mechanic
- Call download lua script in app
- Erlang spawning large amounts of C processes
- does redis cluster support transactions ?
- I am writing an IVR using Lua and want to run xml script in between
- How to read a Bunch of files in a directory in lua
- How to pause a Lua script?
- lua 5.2.3 source lstring.c function luaS_resize
- Torch Lua: Why is my gradient descent not optimizing the error?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
Let's say you took a number
x
.Let
L
be the set of numbers less thanx
in the array, size of the set is|L|
Let
E
be the set of numbers equal tox
in the array, size of the set is|E|
Let
G
be the set of numbers larger thanx
in the array, size of the set is|G|
Let's imagine the sorted array, the first
|L|
numbers(1 -> |L|)
are contained in setL
.The following
|E|
numbers(|L|+1 -> |L|+|E|)
are contained in setE
.The following
|G|
numbers(|L|+|E|+1 -> end)
are contained in setG
.We are looking for the
kth
smallest number, so we have 3 cases:1)
k <= |L|
this means that the number we are looking for is in the first|L|
numbers in the sorted array, so we search for thekth
smallest number inL
.2)
|L| < k <= |L|+|E|
this means that the number we are looking for is in a position between(|L|+1 -> |L|+|E|)
in the sorted array, so it is an element fromE
. Since all elements ofE
are equal tox
, we know that thekth
smallest number is equal tox
.3)
k > |L|+|E|
this means that the number we are looking for is in a position between(|L|+|E|+1 -> end)
in the sorted array, so it is an element from 'G'. Since there are already|L|+|E|
numbers less than thekth
smallest number, we can subtract|L|+|E|
fromk
, let's call itk'
(k' = k - |L| - |E|
), and search for thek'th
smallest element inG
.