๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ

Problem Solving21

Kruskal / Prim Algorithm (ํฌ๋ฃจ์Šค์นผ / ํ”„๋ฆผ ์•Œ๊ณ ๋ฆฌ์ฆ˜) https://www.youtube.com/watch?v=LQ3JHknGy8c : MST ๊ฐœ๋…๊ณผ ํฌ๋ฃจ์Šค์นผ ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์„ค๋ช… (์œ ํˆฌ๋ฒ„ ๋™๋นˆ๋‚˜) https://www.youtube.com/watch?v=AMByrd53PHM : ํฌ๋ฃจ์Šค์นผ์— ์‚ฌ์šฉ๋˜๋Š” union-find ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์„ค๋ช… (์œ ํˆฌ๋ฒ„ ๋™๋นˆ๋‚˜) https://www.youtube.com/watch?v=71UQH7Pr9kU : ํฌ๋ฃจ์Šค์นผ 2๋ถ„์งœ๋ฆฌ ์˜์ƒ https://www.youtube.com/watch?v=cplfcGZmX7I : ํ”„๋ฆผ 2๋ถ„์งœ๋ฆฌ ์˜์ƒ https://stackoverflow.com/questions/1195872/when-should-i-use-kruskal-as-opposed-to-prim-and-vice-versa When should I u.. 2020. 6. 2.
Dijkstra Algorithm (๋‹ค์ต์ŠคํŠธ๋ผ ์•Œ๊ณ ๋ฆฌ์ฆ˜) https://www.youtube.com/watch?v=_lHSawdgXpI : ์ง๊ด€์  ์ดํ•ด ๋„์™€์ฃผ๋Š” 3๋ถ„์งœ๋ฆฌ ์˜์ƒ https://code.google.com/archive/p/eclipselu/downloads : algorithm.pdf์˜ Dijkstra algorithm ๋ถ€๋ถ„ (Pseudocode ์ถœ์ฒ˜) ์•„๋ž˜ ๊ทธ๋ฆผ์˜ ํŒŒ๋ž€์ƒ‰ ํ•œ๊ธ€ ๊ธ€์”จ ์ถœ์ฒ˜๋Š” ๋‚˜ Pseudocode ์ด ์ˆ˜๋„์ฝ”๋“œ์—์„œ๋Š” dist๊ฐ€ ์—…๋ฐ์ดํŠธ๋  ๋•Œ๋งˆ๋‹ค priority queue H์— push ํ•ด์ฃผ๋Š” ๊ฒƒ์ด ์•„๋‹ˆ๋ผ, ์ฒ˜์Œ๋ถ€ํ„ฐ H์— ๋ชจ๋“  ์›์†Œ์— ๋Œ€ํ•œ ์ •๋ณด๋ฅผ ๋„ฃ์–ด์ฃผ๊ณ  dist๊ฐ€ ์—…๋ฐ์ดํŠธ๋˜๋ฉด H์—๋„ ๊ทธ๋ฅผ ์•Œ๋ฆฐ๋‹ค๋Š” ์ปจ์…‰์ด๋‹ค. ์ด๋ฏธ ๋ฐฉ๋ฌธํ•œ ๋…ธ๋“œ๋Š” H์—์„œ ์‚ฌ๋ผ์ง€๋ฏ€๋ฅด unvisited ๋ผ๋Š” ์…‹์„ ์‚ฌ์šฉํ•  ํ•„์š”๊ฐ€ ์—†๋Š” ๊ฒƒ์ด๋‹ค. ํ•˜์ง€๋งŒ ์‹ค์ œ ๊ตฌํ˜„ํ•  ๋•Œ dist.. 2020. 6. 2.
๋ฒ”์œ„ ๊ธฐ๋ฐ˜ ํฌ๋ฌธ (Range-based for loop) for(auto elem: arr) // arr์˜ ์š”์†Œ๊ฐ€ elem์— ๋ณต์‚ฌ for(auto& elem: arr) // arr์˜ ์š”์†Œ์˜ ์ฐธ์กฐ (๊ฐ’ ๋ณ€๊ฒฝ ๊ฐ€๋Šฅ) [๊ถŒ์žฅ] for(const auto& elem: arr) // ์ฝ๊ธฐ ์ „์šฉ + ์ฐธ์กฐ [๊ถŒ์žฅ] ๋ฐฐ์—ด, vector, deque, list, set, map์— ๋ชจ๋‘ ์‚ฌ์šฉ ๊ฐ€๋Šฅ https://boycoding.tistory.com/210 C++ 07.18 - แ„‡แ…ฅแ†ทแ„‹แ…ฑ แ„€แ…ตแ„‡แ…กแ†ซ for แ„†แ…ฎแ†ซ (range-based for statement) แ„‡แ…ฅแ†ทแ„‹แ…ฑ แ„€แ…ตแ„‡แ…กแ†ซ for แ„†แ…ฎแ†ซ (range-based for statement) '06.06 - for ๋ฌธ' ํฌ์ŠคํŠธ์—์„œ for ๋ฌธ์„ ์‚ฌ์šฉํ•˜์—ฌ ๋ฐฐ์—ด์˜ ๊ฐ ์š”์†Œ๋ฅผ ๋ฐ˜๋ณตํ•˜๋Š” ์˜ˆ์ œ๋ฅผ ๋ดค๋‹ค. #include int main.. 2020. 6. 1.
C++ ์ˆœ์ฐจ ์ปจํ…Œ์ด๋„ˆ (vector, deque, list) vector ํƒ€์ž… T๋ฅผ ์›์†Œ๋กœ ๊ฐ–๋Š” ์ˆœ์ฐจ ์ปจํ…Œ์ด๋„ˆ๋กœ ํ˜„์žฌ ํ• ๋‹น๋œ ์šฉ๋Ÿ‰(capacity)์„ ์ดˆ๊ณผํ•˜๋Š” ์ฆ‰์‹œ ๋” ๋งŽ์€ ์›์†Œ๋ฅผ ์ €์žฅํ•  ์ˆ˜ ์žˆ๋Š” ์ถ”๊ฐ€ ๊ณต๊ฐ„์ด ์ž๋™์œผ๋กœ ํ• ๋‹น๋œ๋‹ค. ์ปจํ…Œ์ด๋„ˆ์˜ ๋์—์„œ ์›์†Œ๋ฅผ ์ถ”๊ฐ€ ๋˜๋Š” ์‚ญ์ œํ•  ๋•Œ๋งŒ ํšจ์œจ์ ์ด๋‹ค. - ์šฉ๋Ÿ‰/ํฌ๊ธฐ: capacity(), reserve(), size(), resize(), empty() - ์›์†Œ ์ ‘๊ทผ: [], at(), front(), back() - ์›์†Œ ์ถ”๊ฐ€: push_back(), emplace_back(), emplace(), insert() - ์›์†Œ ์‚ญ์ œ: clear(), pop_back(), erase() deque ํƒ€์ž… T์˜ ์›์†Œ๋“ค์„ deque(double-ended queue)๋กœ ์ €์žฅํ•˜๋Š” ์ปจํ…Œ์ด๋„ˆ์ด๋‹ค. ์ˆœ์ฐจ์—ด์˜ ์‹œ์ž‘์ด๋‚˜ ๋์— ๊ฐ์ฒด๋“ค์„ ํšจ์œจ์ ์œผ๋กœ .. 2020. 5. 31.