Las Vegas Algorithm
- English ๐บ๐ธ
- ํ๊ตญ์ด ๐ฐ๐ท
A Las Vegas algorithm is a randomized algorithm that always produces a correct result or outputs that it has failed to find a solution. Randomness comes into play regarding the time taken to get a result. Unlike the Monte Carlo algorithms, which may produce incorrect results with a certain probability, a Las Vegas algorithm ensures that it is correct when it does have an impact.
An illustrative example is the Quickselect algorithm, a cousin of the Quicksort algorithm. Quickselect finds the -th smallest element of an unordered list. While it uses randomness to achieve its expected runtime, it always provides the correct element as an answer.
Interestingly, Las Vegas always gives the correct results but sometimes gives a very slow answer. You bet (risk) on time on the promise of accurate resultsโanother exciting property in Computational Theory.
๋ผ์ค๋ฒ ๊ฐ์ค ์๊ณ ๋ฆฌ์ฆ์ ๋ฌด์์ ์๊ณ ๋ฆฌ์ฆ์ผ๋ก, ํญ์ ์ฌ๋ฐ๋ฅธ ๊ฒฐ๊ณผ๋ฅผ ์ฐ์ถํ๊ฑฐ๋ ํด๊ฒฐ์ฑ ์ ์ฐพ์ง ๋ชปํ๋ค๊ณ ์ถ๋ ฅํ๋ค. ๊ฒฐ๊ณผ๋ฅผ ์ป๋ ๋ฐ ๊ฑธ๋ฆฌ๋ ์๊ฐ๊ณผ ๊ด๋ จํ์ฌ ๋ฌด์์์ฑ์ด ์์ฉํ๋ค. ํน์ ํ๋ฅ ๋ก ์๋ชป๋ ๊ฒฐ๊ณผ๋ฅผ ์์ฑํ ์ ์๋ ๋ชฌํ ์นด๋ฅผ๋ก ์๊ณ ๋ฆฌ์ฆ๊ณผ ๋ฌ๋ฆฌ, ๋ผ์ค๋ฒ ๊ฐ์ค ์๊ณ ๋ฆฌ์ฆ์ ์ ํํ ๊ฒฐ๊ณผ๋ฅผ ๋ณด์ฅํ๋ค.
ํต์ํธ ์๊ณ ๋ฆฌ์ฆ์ ๋ณํ์ธ ํต์ ๋ ํธ ์๊ณ ๋ฆฌ์ฆ์ ์๋ก ๋ค ์ ์๋ค. ํต์ ๋ ํธ๋ ์ ๋ ฌ๋์ง ์์ ๋ชฉ๋ก์์ ๋ฒ์งธ๋ก ์์ ์์๋ฅผ ์ฐพ๋๋ค. ์์ ์คํ ์๊ฐ์ ๋ฌ์ฑํ๊ธฐ ์ํด ๋ฌด์์์ฑ์ ์ฌ์ฉํ์ง๋ง, ํญ์ ์ฌ๋ฐ๋ฅธ ์์๋ฅผ ์ ๋ต์ผ๋ก ์ ๊ณตํ๋ค.
๋ง์ฐฌ๊ฐ์ง๋ก ํฅ๋ฏธ๋ก์ด ์ ์, ๋ผ์ค๋ฒ ๊ฐ์ค ์๊ณ ๋ฆฌ์ฆ์ ์ถ์ฐ์น์ ๊ฐ์ ๋งค์ฐ ์ ํํ์ง๋ง ์์ฃผ ๋ฎ์ ํ๋ฅ ๋ก ์๊ฐ์ด ์์ฒญ๋๊ฒ ์ค๋ ๊ฑธ๋ฆฐ๋ค๋ ๊ฒ์ด๋ค. ์ฆ ์ ํ๋๋ฅผ ์ฝ์ ๋ฐ๋ ๋์ ์๊ฐ์ ๋ฆฌ์คํฌ๋ฅผ ๊ฑฐ๋ ๊ฒ์ด๋ค. ๋ง์ฐฌ๊ฐ์ง๋ก ๊ณ์ฐ ์ด๋ก ์์ ํฅ๋ฏธ๋ก์ด ์ ์ด ์๋ ์ ์๋ค.