๐Ÿงฉ Problem Solving/[์•Œ๊ณ ๋ฆฌ์ฆ˜ for PS]

๐Ÿงฉ Problem Solving/[์•Œ๊ณ ๋ฆฌ์ฆ˜ for PS]

[์•Œ๊ณ ๋ฆฌ์ฆ˜] ๊ทธ๋ฆฌ๋”” ์•Œ๊ณ ๋ฆฌ์ฆ˜ (Greedy Algorithm)

๊ทธ๋ฆฌ๋”” ์•Œ๊ณ ๋ฆฌ์ฆ˜(Greedy Algorithm) ํƒ์š•๋ฒ•์œผ๋กœ๋„ ์•Œ๋ ค์ง„ ๋ฌธ์ œ ํ•ด๊ฒฐ ๋ฐฉ๋ฒ•์ด๋‹ค. ์ด๋ฆ„ ๊ทธ๋Œ€๋กœ ์ฃผ์–ด์ง„ ๋ฌธ์ œ๋ฅผ ๋‹จ์ˆœํ•˜๊ฒŒ ํƒ์š•์ ์œผ๋กœ ํ‘ธ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜์ด๋‹ค. ํƒ์š•์ ์ด๋ผ๋Š” ๋ง์€ 'ํ˜„์žฌ ์ƒํ™ฉ์—์„œ ๊ฐ€์žฅ ์ข‹์€ ๊ฒƒ๋งŒ ๊ณ„์† ๊ณ ๋ฅด๋Š” ๋ฐฉ๋ฒ•'์„ ๋งํ•œ๋‹ค. ๊ทธ๋ฆฌ๋”” ๋ฐฉ๋ฒ•์Œ ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ๊ฐ ๋‹จ๊ณ„์—์„œ ๊ทธ ์ˆœ๊ฐ„์— ์ตœ์ ์ด๋ผ๊ณ  ์ƒ๊ฐํ•˜๋Š” ๊ฒƒ์„ ์„ ํƒํ•œ๋‹ค. ๋˜ํ•œ ๊ทธ๋ฆฌ๋””๋กœ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ• ๋•Œ๋Š” ํ˜„์žฌ์˜ ์„ ํƒ์ด ๋งˆ์ง€๋ง‰ ํ•ด๋‹ต์˜ ์ตœ์ ์„ฑ์„ ํ•ด์น˜์ง€ ์•Š์„ ๋•Œ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค. ์šฐ๋ฆฌ๋Š” ๊ทธ๋ฆฌ๋“œ ๋ฌธ์ œ๋ฅผ ํ’€ ๋•Œ๋Š” ๋‹ค์ต์ŠคํŠธ๋ผ(dijkstra) ๋˜๋Š” ์œ„์ƒ ์ •๋ ฌ(topological sort) ์•Œ๊ณ ๋ฆฌ์ฆ˜์ฒ˜๋Ÿผ ํŠน์ • ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์ฝ”๋“œ๋ฅผ ๋ฏธ๋ฆฌ ์•Œ ํ•„์š”๋Š” ์—†๋‹ค. ๋Œ€์‹  ์šฐ๋ฆฌ๋Š” ๋ฌธ์ œ๋ฅผ ๋ดค์„ ๋•Œ '๊ทธ ๋ฌธ์ œ๊ฐ€ ๊ทธ๋ฆฌ๋“œ ์•Œ๊ณ ๋ฆฌ์ฆ˜์œผ๋กœ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ๋Š”์ง€'์— ๋Œ€ํ•ด ์•Œ์•„์•ผ ํ•œ๋‹ค. ๊ทธ๋Ÿผ ์–ด๋–ป๊ฒŒ ์•Œ ์ˆ˜ ์žˆ..

์ œ๋ด‰์•„
'๐Ÿงฉ Problem Solving/[์•Œ๊ณ ๋ฆฌ์ฆ˜ for PS]' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๊ธ€ ๋ชฉ๋ก