์ „์ฒด ๊ธ€

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

์™•์‹ค์˜ ๊ธฐ์‚ฌ ๋Œ€๊ฒฐ(์‚ผ์„ฑ sw์—ญ๋Ÿ‰ํ…Œ์ŠคํŠธ)

https://www.codetree.ai/training-field/frequent-problems/problems/royal-knight-duel/description?page=1&pageSize=20 ๊ตฌํ˜„ + bfs ํ’€์ด๊ณผ์ • 0. ๋ชจ๋“ˆํ™”๋œ ํ•จ์ˆ˜๋ฅผ ๋‹ค ํ˜ธ์ถœํ•˜๋Š” solveํ•จ์ˆ˜. static void solve(int n,int d) { if(knights[n].isOut) return; // 1. ํ•ด๋‹น ๋ฐฉํ–ฅ์œผ๋กœ ์ด๋™์ด ๊ฐ€๋Šฅํ•œ์ง€ ํ™•์ธํ•˜๊ธฐ if(!movable(n,d)) return; // 2. ์ด๋™์‹œํ‚ค๊ธฐ moved = new boolean[N+1]; move(n, d); moved[n] = false; // ๋ช…๋ น๋ฐ›์€ n๋ฒˆ ๊ธฐ์‚ฌ๋Š” ์›€์ง์ž„์—์„œ ์ œ์™ธ // 3. ๋ฐ๋ฏธ์ง€ ๊ณ„์‚ฐํ•˜๊ธฐ (๋ช…๋ น์„ ๋ฐ›์€ n๋ฒˆ ๊ธฐ์‚ฌ๋Š” ๋ฐ๋ฏธ์ง€..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

๋ฃจ๋Œํ”„์˜ ๋ฐ˜๋ž€(์‚ผ์„ฑ sw์—ญ๋Ÿ‰ํ…Œ์ŠคํŠธ)

https://www.codetree.ai/training-field/frequent-problems/problems/rudolph-rebellion/description?page=1&pageSize=20 ์ฝ”๋“œํŠธ๋ฆฌ | ์ฝ”๋”ฉํ…Œ์ŠคํŠธ ์ค€๋น„๋ฅผ ์œ„ํ•œ ์•Œ๊ณ ๋ฆฌ์ฆ˜ ์ •์„ ๊ตญ๊ฐ€๋Œ€ํ‘œ๊ฐ€ ๋งŒ๋“  ์ฝ”๋”ฉ ๊ณต๋ถ€์˜ ๊ฐ€์ด๋“œ๋ถ ์ฝ”๋”ฉ ์™•์ดˆ๋ณด๋ถ€ํ„ฐ ๊ฟˆ์˜ ์ง์žฅ ์ฝ”ํ…Œ ํ•ฉ๊ฒฉ๊นŒ์ง€, ๊ตญ๊ฐ€๋Œ€ํ‘œ๊ฐ€ ์—„์„ ํ•œ ์ปค๋ฆฌํ˜๋Ÿผ์œผ๋กœ ์ค€๋น„ํ•ด๋ณด์„ธ์š”. www.codetree.ai ํ’€์ด๊ณผ์ • ํ•จ์ˆ˜๋ณ„๋กœ ๋ชจ๋“ˆํ™”๋ฅผ ์ž˜ ์‹œ์ผœ์•ผํ–ˆ์œผ๋ฉฐ, ๊ตฌํ˜„๊ณผ์ •์ด ๋ณต์žกํ•˜๋‹ค ๋ณด๋‹ˆ ์ฒ˜์Œ ์‹œ์ž‘ํ•  ๋•Œ ์ž๋ฃŒ๊ตฌ์กฐ๋ฅผ ์ž˜ ์ •ํ•ด์„œ ์‚ฌ์šฉํ•ด์•ผ ํ–ˆ์Šต๋‹ˆ๋‹ค. ์‚ฌ์šฉํ•œ ํด๋ž˜์Šค์™€ ๋ณ€์ˆ˜ ์ „์ฒด์ ์ธ ์‚ฐํƒ€์™€ ๋ฃจ๋Œํ”„์˜ ์œ„์น˜๋Š” 2์ฐจ์› ๋ฐฐ์—ด(int[][] map)์— ์ •์ˆ˜ํ˜•์œผ๋กœ ์ €์žฅํ•˜๊ณ , ์„ธ๋ถ€์ •๋ณด๋ฅผ ์ €์žฅํ•˜๋Š” ๋ณ€์ˆ˜๋ฅผ ๋งŒ๋“ค์–ด์„œ 2์ฐจ์› ๋ฐฐ์—ด(int[][] ..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[๋ฐฑ์ค€] ์›ํŒ ๋Œ๋ฆฌ๊ธฐ

https://www.acmicpc.net/problem/17822 ํ’€์ด๊ณผ์ • 1. ์›ํŒ์„ ํšŒ์ „์‹œํ‚ค๋Š” ํ•จ์ˆ˜๋ฅผ ๊ตฌํ˜„ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ArrayList ํ˜น์€ LinkedList๋ฅผ ์‚ฌ์šฉํ•ด์„œ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. add, insert ,remove ํ•จ์ˆ˜๋ฅผ ํ™œ์šฉํ•˜์—ฌ ์›ํŒ์˜ ํšŒ์ „์„ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. 2. ์›ํŒ์—์„œ ์ธ์ ‘ํ•œ ์ˆซ์ž๋“ค ๋ผ๋ฆฌ ์ผ์น˜์—ฌ๋ถ€๋ฅผ ํ™•์ธํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. dfs๋ฅผ ํ†ตํ•ด ์ธ์ ‘์—ฌ๋ถ€๋ฅผ ๊ตฌํ˜„ํ•ฉ๋‹ˆ๋‹ค. ์ธ์ ‘ํ•˜๊ฒŒ ๋˜๋ฉด -1๋กœ ์›์†Œ๋ฅผ ๋ณ€๊ฒฝํ•˜์—ฌ ์ฒดํฌํ–ˆ์Šต๋‹ˆ๋‹ค. ์ด๋•Œ ๊ฐ™์€ ์›ํŒ ๋‚ด์—์„œ์˜ ์ˆœํšŒ(?)๋ฅผ ๊ตฌํ˜„ํ•ด์ค˜์•ผ ํ•ฉ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ๋“ค์–ด [2,3,4,2] ์™€ ๊ฐ™์€ ์›ํŒ์ธ ๊ฒฝ์šฐ ์ œ์ผ ์•ž ์›์†Œ 2์™€ ์ œ์ผ ๋’ค ์›์†Œ 2๋Š” ์ธ์ ‘ํ•ด ์žˆ์Šต๋‹ˆ๋‹ค. ๋”ฐ๋ผ์„œ dfs์ˆ˜ํ–‰ ์ค‘ ์ธ๋ฑ์Šค๊ฐ€ -1์ด ๋˜๋ฉด 3์œผ๋กœ, 4๊ฐ€ ๋˜๋ฉด 0์œผ๋กœ ๋ณด์ •์„ ํ•ด์ค˜์•ผ ํ•ฉ๋‹ˆ๋‹ค. static bo..

๐Ÿ’Ž๋ฐฑ์—”๋“œ : Backend

๋™์‹œ์„ฑ ์ฒ˜๋ฆฌ

์˜ˆ์ „ ๋ฑ…ํ‚น ์„œ๋น„์Šค๋ฅผ ์ฃผ์ œ๋กœ ํ•œ ํ”„๋กœ์ ํŠธ๋ฅผ ์ง„ํ–‰ํ–ˆ์ง€๋งŒ, ๋™์‹œ์„ฑ์— ๋Œ€ํ•œ ์ฒ˜๋ฆฌ๋ฅผ ํ•ด์ฃผ์ง€ ๋ชป ํ•œ ์ ์„ ๋ณด์™„ํ•˜๊ธฐ ์œ„ํ•ด ๊ณต๋ถ€ํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•œ ๊ธ€์ž…๋‹ˆ๋‹ค. ๋™์‹œ์„ฑ ์ด์Šˆ ํ•ด๊ฒฐ๋ฐฉ๋ฒ• synchronized ํ•˜๋‚˜์˜ ํ”„๋กœ์„ธ์Šค์—์„œ๋งŒ ๋™์ž‘. ์ฆ‰ ์„œ๋ฒ„๊ฐ€ ์—ฌ๋Ÿฌ๋Œ€์ด๊ณ  ์„œ๋กœ ๋‹ค๋ฅธ ์„œ๋ฒ„์—์„œ ๋™์‹œ์— ์ ‘๊ทผํ•œ๋‹ค๋ฉด synchronized ๋Š” ๊ธฐ๋Šฅ์„ ๋ฐœํœ˜ํ•  ์ˆ˜ ์—†๋‹ค. @Transactional ์„ ์‚ฌ์šฉํ•˜๋ฉด, ํŠธ๋žœ์žญ์…˜์ด ์ปค๋ฐ‹ํ•  ๋•Œ ์ž ๊น์˜ ํ…€์— ๋‹ค๋ฅธ ์Šค๋ ˆ๋“œ๊ฐ€ ์ ‘๊ทผํ•  ์ˆ˜ ์žˆ์–ด์„œ ๋™์‹œ์„ฑ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•  ์ˆ˜ ์—†๋‹ค. Lock (DB์—์„œ ์žฌ๊ณตํ•˜๋Š” ๋ฝ๊ธฐ๋Šฅ์„ ์‚ฌ์šฉ) Pessimistic Lock (๋น„๊ด€์  ๋ฝ) row๋‚˜ table ๋‹จ์œ„๋กœ ๋ฝ์„ ๊ฒ€ ์ž์› ์š”์ฒญ์— ๋”ฐ๋ฅธ ๋™์‹œ์„ฑ ๋ฌธ์ œ๊ฐ€ ๋ฐœ์ƒํ•  ๊ฒƒ์ด๋ผ๊ณ  ์˜ˆ์ƒํ•˜๊ณ  ๋ฝ์„ ๊ฑธ์–ด๋ฒ„๋ฆฌ๋Š” ๋น„๊ด€์  ๋ฝ ๊ณต์œ ๋ฝ(Shared Lock)๊ณผ ๋ฒ ํƒ€๋ฝ..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[๋ฐฑ์ค€] ์—ฐ๊ตฌ์†Œ 3 (์กฐํ•ฉ, bfs)

https://www.acmicpc.net/problem/17142 ํ’€์ด๊ณผ์ • 0. ์ž…๋ ฅ์„ ๋ฐ›์„ ๋•Œ ์ฑ„์›Œ์•ผ ํ•  ๋นˆ์นธ์˜ ๊ฐฏ์ˆ˜๋ฅผ ์ €์žฅํ•ฉ๋‹ˆ๋‹ค. 1. ๋ฐฑํŠธ๋ž˜ํ‚น์„ ํ™œ์šฉํ•ด์„œ ๋ฐ”์ด๋Ÿฌ์Šค๋“ค์˜ ์กฐํ•ฉ์„ ์„ ํƒํ•ฉ๋‹ˆ๋‹ค. 2. ์„ ํƒ๋œ ๋ฐ”์ด๋Ÿฌ์Šค๋“ค์— ๋Œ€ํ•ด bfs๋ฅผ ์ˆ˜ํ–‰ํ•˜์—ฌ ํผํŠธ๋ฆฝ๋‹ˆ๋‹ค. ๋ฐ”์ด๋Ÿฌ์Šค๋ฅผ ํผํŠธ๋ฆด ๋•Œ, ๋นˆ์นธ๊ณผ ๋ฐ”์ด๋Ÿฌ์Šค๊ฐ€ ์žˆ๋Š” ์นธ์— ๋Œ€ํ•ด ๊ตฌ๋ถ„ํ•ด์„œ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ๋นˆ ์นธ์˜ ๊ฒฝ์šฐ 0๋ฒˆ ํ’€์ด๊ณผ์ •์—์„œ ์ €์žฅํ•œ ๋ชฉํ‘œ์™€ ๋น„๊ตํ•˜๊ธฐ ์œ„ํ•ด cnt๊ฐ’์„ ์ฆ๊ฐ€์‹œ์ผœ ์ค๋‹ˆ๋‹ค. ๋ฐ”์ด๋Ÿฌ์Šค์˜ ๊ฒฝ์šฐ cnt ๊ฐ’์„ ์ฆ๊ฐ€์‹œํ‚ค์ง€ ์•Š๊ณ  ๋ฐฉ๋ฌธ์ฒ˜๋ฆฌ์™€ bfsํ์— ๋„ฃ๋Š” ๋™์ž‘๋งŒ ์ˆ˜ํ–‰ํ•ฉ๋‹ˆ๋‹ค. ์ฒ˜์Œ์—๋Š” swea์˜ ์ง€๋ขฐ๋ฌธ์ œ์™€ ํ—ท๊ฐˆ๋ ค์„œ ๋ฐ”์ด๋Ÿฌ์Šค๋ฅผ ๋งŒ๋‚˜๋ฉด ๊ณ„์† ํผ์ง€๋„๋ก ๊ตฌํ˜„ํ•ด์„œ ๊ณ„์† ํ‹€๋ ธ์Šต๋‹ˆ๋‹ค ใ… ใ…  3. ๋นˆ ์นธ์„ ๋‹ค ์ฑ„์› ์œผ๋ฉด ์ด๋™ํ•œ ์‹œ๊ฐ„์„ return ํ•ฉ๋‹ˆ๋‹ค. bfs์—์„œ ์‹œ๊ฐ„์€ ๊ณ„์†..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

๋ฐฐ์—ด ์‹œ๊ณ„๋ฐฉํ–ฅ ํšŒ์ „ ๊ณต์‹

N = ํ–‰ ๊ธธ์ด M = ์—ด ๊ธธ์ด int[][] origin = { {1,2,3}, {4,5,6}, {7,8,9} }; // ์›๋ณธ ๋ฐฐ์—ด int[][] result; // ํšŒ์ „ ๋ฐฐ์—ด ์‹œ๊ณ„ ๋ฐฉํ–ฅ 90๋„ ํšŒ์ „ : (i,j) = (N-1-j, i) ํ˜น์€ (j, N-1-i) = (i,j) for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { rotate_arr[i][j] = arr[N - 1 - j][i]; } } ๋ฐ˜ ์‹œ๊ณ„ ๋ฐฉํ–ฅ 90๋„ ํšŒ์ „ : (i,j) = (j, N-1-i) ํ˜น์€ (N-1-j, i) = (i, j) for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { rotate_arr[i][j] = ar..

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

ํˆฌํฌ์ธํ„ฐ ์•Œ๊ณ ๋ฆฌ์ฆ˜

๊ตฌํ˜„ ์ฝ”๋“œ๋งŒ ๊ฐ„๋žตํ•˜๊ฒŒ ์ž‘์„ฑ..(์™ธ์šฐ๊ธฐ ์œ„ํ•ด์„œ ๐Ÿ˜‚) ๋ฆฌ์ŠคํŠธ์— ์ˆœ์ฐจ์ ์œผ๋กœ ์ ‘๊ทผํ•ด์•ผ ํ•  ๋•Œ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ํˆฌ ํฌ์ธํ„ฐ ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๊ธฐ๋ณธ ํฌ๋ฉงint N = 5; // ๋ฐ์ดํ„ฐ์˜ ๊ฐœ์ˆ˜ Nint M = 5; // ์ฐพ๊ณ ์ž ํ•˜๋Š” ๋ถ€๋ถ„ ํ•ฉ Mint[] data = {1,2,3,2,5};int cnt = 0;int interval_sum = 0;int end = 0;for(int start=0;start

๐Ÿฅ‡์ฝ”๋”ฉํ…Œ์ŠคํŠธ:Algorithm

[๋ฐฑ์ค€] ๋“œ๋ž˜๊ณค ์ปค๋ธŒ (๊ตฌํ˜„)

๋ฌธ์ œ : https://www.acmicpc.net/problem/15685 ํ’€์ด๊ณผ์ • 1. ๋“œ๋ž˜๊ณค ์ปค๋ธŒ๋ฅผ ๊ทธ๋ฆฌ๋Š” ํ•จ์ˆ˜๋ฅผ ๊ตฌํ˜„ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. 1-1. ๋ฆฌ์ŠคํŠธ๋ฅผ ํ™œ์šฉ ๋“œ๋ž˜๊ณค ์ปค๋ธŒ๋Š” ํ˜„์žฌ๊นŒ์ง€ ๋งŒ๋“ค์–ด์ง„ ๋ชจ์–‘์„ ๋ฐ”ํƒ•์œผ๋กœ ์ƒˆ๋กœ์šด ๋ชจ์–‘์„ ๋งŒ๋“ค๊ฒŒ ๋ฉ๋‹ˆ๋‹ค. ๋ฆฌ์ŠคํŠธ๋ฅผ ํ™œ์šฉํ•ด์„œ ๋“œ๋ž˜๊ณค ์ปค๋ธŒ์˜ ๋ฐฉํ–ฅ์„ ๊ตฌํ˜„ํ–ˆ์Šต๋‹ˆ๋‹ค. 1-2. 90๋„ ํšŒ์ „ 90๋„ ํšŒ์ „์˜ ๊ฒฝ์šฐ 0 ๋ฐฉํ–ฅ์€ 1 1 ๋ฐฉํ–ฅ์€ 2 2 ๋ฐฉํ–ฅ์€ 3 3 ๋ฐฉํ–ฅ์€ 0 ์ด ๋ฉ๋‹ˆ๋‹ค. (ํ˜„์žฌ๋ฐฉํ–ฅ+1)%4 ์—ฐ์‚ฐ์„ ํ†ตํ•ด ์ด๋ฅผ ๊ตฌํ˜„ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. static void update_history(){ // g๋ฒˆ ์ด๋™์‹œํ‚ค๊ธฐ for(int i=0;i=0;j--){ history.add((history.get(j)+1)%4); } } } 1-3. ๋‘ ๋ฒˆ ์ด๋™ ์‹œํ‚ค๊ธฐ ์ •์‚ฌ๊ฐํ˜•์˜ ๊ฐฏ์ˆ˜๋ฅผ ๊ตฌํ•˜๊ธฐ ์œ„ํ•ด ๋“œ..

mc.thd
mincheolsong