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

๐Ÿ“š Algorithm/9oormthon Challenge

(11)
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 15 ๊ณผ์ผ ๊ตฌ๋งค - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 15์ผ์ฐจ - ๊ณผ์ผ ๊ตฌ๋งค ๐Ÿ“œ ๋ฌธ์ œ โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ๊ทธ๋ฆฌ๋”” ์•Œ๊ณ ๋ฆฌ์ฆ˜์œผ๋กœ ํ’€ ์ˆ˜ ์žˆ๋Š” ์ด๋ฒˆ ๋ฌธ์ œ๋Š” 3์ฃผ์ฐจ์—์„œ ๋น„๊ต์  ์‰ฌ์šด ๋ฌธ์ œ์˜€๋‹ค. P(๊ณผ์ผ ๊ฐ€๊ฒฉ), C(ํฌ๋งŒ๊ฐ)์„ ์ž…๋ ฅ ๋ฐ›๊ณ , ๊ฐ ๊ณผ์ผ์˜ ์กฐ๊ฐ๋งˆ๋‹ค ๊ฐ€์ง€๋Š” ํฌ๋งŒ๊ฐ์„ value๋ผ๊ณ  ์ •ํ•ด fruit ๋ฆฌ์ŠคํŠธ์— ํ•œ ๋ฒˆ์— ๋„ฃ์—ˆ๋‹ค. ๊ทธ๋ฆฌ๊ณ  ๊ฐ€๊ฒฉ์€ ์‹ธ๋ฉด์„œ ํฌ๋งŒ๊ฐ์ด ๋†’์•„์•ผํ•˜๊ธฐ ๋•Œ๋ฌธ์— value๋ฅผ ๊ธฐ์ค€์œผ๋กœ ๋‚ด๋ฆผ์ฐจ์ˆœ ์ •๋ ฌ์„ ํ–ˆ๋‹ค. N, K = map(int, input().split()) #N:๊ณผ์ผ์˜๊ฐœ์ˆ˜, K:๊ฐ€์ง„๋ˆ fruit=[] cnt = 0 for i in range(N) : P, C = map(int, input().split()) #P:๊ฐ ๊ณผ์ผ์˜ ๊ฐ€๊ฒฉ, C:ํฌ๋งŒ๊ฐ value = C // P fruit.append([P, C, value]) f..
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 13 ๋ฐœ์ „๊ธฐ 2 - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 13์ผ์ฐจ - ๋ฐœ์ „๊ธฐ 2 ๐Ÿ“œ ๋ฌธ์ œ โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ๊ทธ๋ฆผ์œผ๋กœ ์กฐ๊ธˆ ๋” ์‰ฝ๊ฒŒ ์ ‘๊ทผํ•ด๋ดค๋‹ค. ๊ฐ€์žฅ ๋งŽ์€ ๋‹จ์ง€๋ฅผ ๋ณด์œ ํ•œ ๊ฑด๋ฌผ์˜ ์œ ํ˜•์„ ์ฐพ์•„์•ผ ํ•˜๊ธฐ ๋•Œ๋ฌธ์—, ๊ฑด๋ฌผ์˜ ๊ฐœ์ˆ˜๋„ ์„ธ์ฃผ๊ณ  temp์™€ cnt๋ฅผ ๋น„๊ตํ•ด์„œ ๊ฐ€์žฅ ๋งŽ์€ ๋‹จ์ง€๊ฐ€ ๋‚˜์˜จ ๊ฑด๋ฌผ ์œ ํ˜•์„ ์ฐพ๋„๋ก ํ–ˆ๋‹ค. N, K = map(int, input().split()) town = [list(map(int, input().split())) for _ in range(N)] dy = [-1, 1, 0, 0] dx = [0, 0, -1, 1] def dfs(i, j): stack = [(i, j)] #๊ฑด๋ฌผ์˜ ์œ ํ˜•์„ ๋ฏธ๋ฆฌ ์ €์žฅ building_type = town[i][j] cnt = 0 while stack: y, x = stack.pop() i..
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 9 ํญํƒ„ ๊ตฌํ˜„ํ•˜๊ธฐ 2 - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 9์ผ์ฐจ - ํญํƒ„ ๊ตฌํ˜„ํ•˜๊ธฐ 2 ๐Ÿ“œ ๋ฌธ์ œ 1๋ฒˆ๊ณผ ๊ฐ™์€ ๊ทธ๋ฆผ์—์„œ ๋งŒ์•ฝ (2, 2)์— ํญํƒ„์ด ๋–จ์–ด์ง€๋ฉด, ์ƒํ•˜์ขŒ์šฐ๋ฅผ ํƒ์ƒ‰ํ•ด์•ผ ํ•œ๋‹ค. (3, 2)๋Š” #์ด๋ฏ€๋กœ ์•„๋ฌด๊ฒƒ๋„ ๋”ํ•˜์ง€ ์•Š๋Š”๋‹ค. (2, 3)์— ํญํƒ„์ด ๋–จ์–ด์ง€๋ฉด, ์ƒํƒœ๊ฐ€ '@'์ธ ๊ณณ์—๋Š” 2๋งŒํผ ํญํƒ„์˜ ์˜ํ–ฅ์„ ๋ฐ›๋Š”๋‹ค. โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ๋ฌธ์ œ์—์„œ '์ƒํ•˜์ขŒ์šฐ'๋ฅผ ๋ณด์ž๋งˆ์ž Graph ๊ฐ€ ์ƒ๊ฐ์ด ๋‚ฌ๋‹ค. ๋จผ์ € ํญํƒ„์ด ๋–จ์–ด์ง€๋ฉด ์ƒํ•˜์ขŒ์šฐ๋กœ ์˜ํ–ฅ์„ ๋ฐ›๋Š”๋‹ค. ๋งŒ์•ฝ (y, x)์— ํญํƒ„์ด ๋–จ์–ด์ง€๋ฉด ์˜ํ–ฅ์€ (y-1, x), (y, x-1), (y+1, x), (y, x+1)์— ๋ฐ›๋Š”๋‹ค. ์ขŒํ‘œ๋ฅผ ์กฐ๊ธˆ ๋” ์‰ฝ๊ฒŒ ๊ณ„์‚ฐํ•˜๊ธฐ ์œ„ํ•ด dx = [0, 1, -1, 0, 0] , dy = [0, 0, 0, 1, -1]๋กœ ํ•˜์˜€๋‹ค. #๋Š” ๋ณ€ํ™”๊ฐ€ ์—†๊ณ , '0'์€ +1, '@'์€ +2..
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 8 ํ†ต์ฆ - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 8์ผ์ฐจ - ํ†ต์ฆ ๐Ÿ“œ ๋ฌธ์ œ โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ์ฒ˜์Œ์—๋Š” ์กฐ๊ฑด๋ฌธ์—์„œ N์˜ ๋ฒ”์œ„๋ฅผ ๋”ฐ์ ธ 1์ผ ๊ฒฝ์šฐ, 7๋ณด๋‹ค ์ž‘์„ ๊ฒฝ์šฐ, 14๋ณด๋‹ค ์ž‘์„ ๊ฒฝ์šฐ๋กœ ๊ณ„์‚ฐ์„ ํ–ˆ๋‹ค. ์˜ค๋‹ต์ด์˜€๋‹ค. ๋‚ด๊ฐ€ ๋†“์นœ ์กฐ๊ฑด๋“ค์„ ๋‹ค์‹œ ์ฐพ์•„ ๋‹ค์‹œ ์ œ์ถœ์„ ํ•˜๋‹ˆ ์ •๋‹ต์ด์˜€๋‹ค. N์˜ ๋ฒ”์œ„๋ฅผ ๋”ฐ์ ธ ์กฐ๊ฑด๋ฌธ์„ ์ž‘์„ฑํ•˜๋˜, 1์ผ ๊ฒฝ์šฐ์— ์ด์ค‘์กฐ๊ฑด๋ฌธ์œผ๋กœ ๋‹ค์‹œ ๊ณ„์‚ฐ์„ ๋ฐ˜๋ณตํ•˜๊ฒŒ ํ–ˆ๋‹ค. N = int(input()) res = 0 if N < 7 : res += N elif N < 14 : res += N - 6 else : res += N//14 N %= 14 if N < 7 : res += N else : res += N - 6 print(res) ๋ฌธ์ œ ์ถœ์ฒ˜ : https://level.goorm.io/exam/195690/%ED%86%B5%EC%..
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 7 ๊ตฌ๋ฆ„ ์ฐพ๊ธฐ ๊นƒ๋ฐœ - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 7์ผ์ฐจ - ๊ตฌ๋ฆ„ ์ฐพ๊ธฐ ๊นƒ๋ฐœ ๐Ÿ“œ ๋ฌธ์ œ โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ํ–‰๋ ฌ ๊ฐ’์ด 0์ผ๋•Œ ์ธ์ ‘ํ•œ 8์นธ ์ค‘์—์„œ ๊ตฌ๋ฆ„์ด K๊ฐœ ์žˆ๋Š” ์นธ์˜ ๊ฐœ์ˆ˜๋ฅผ ๊ตฌํ•˜๋Š” ๋ฌธ์ œ์ด๋‹ค. ๋ชจ๋“  ์นธ์„ ํ™•์ธํ•˜๋ฉด์„œ ๋น„์–ด์žˆ๋Š” ๊ฒฝ์šฐ์— ๊ฐœ์ˆ˜๋ฅผ ์„ธ๋„๋ก ํ•˜์˜€๋‹ค. n, k = map(int, input().split()) mat = [input().split() for i in range(n)] dy, dx = [-1, -1, -1, 0, 0, 1, 1, 1], [-1, 0, 1, -1, 1, -1, 0, 1] for i in range(n): for j in range(n): if mat[i][j] == '0': flag = 0 for a in range(8): y, x = i + dy[a], j + dx[a] if y ..
[๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ - 9oormthon Challenge] Day 6 ๋ฌธ์ž์—ด ๋‚˜๋ˆ„๊ธฐ - Python ํŒŒ์ด์ฌ ํ’€์ด ๊ตฌ๋ฆ„ํ†ค ์ฑŒ๋ฆฐ์ง€ 6์ผ์ฐจ - ๋ฌธ์ž์—ด ๋‚˜๋ˆ„๊ธฐ ๐Ÿ“œ ๋ฌธ์ œ โœ๏ธ ์ž…๋ ฅ โœ๏ธ ์ถœ๋ ฅ ๐Ÿ’ก ํ’€์ด ์ง€๋‚œ์ฃผ ๋ฌธ์ œ๋“ค์— ๋น„ํ•ด ์กฐ๊ธˆ ๋‚œ์ด๋„๊ฐ€ ์žˆ์—ˆ๋˜ ๊ฒƒ ๊ฐ™๋‹ค. ๋ฌธ์ œ ๊ณต๊ฐœ ๋‹น์ผ๊นŒ์ง€ ํ’€์ง€๋Š” ๋ชปํ•˜๊ณ  ๋‹ค์Œ๋‚  ์˜ค์ „์— ํ’€๊ฒŒ๋˜์—ˆ๋‹ค. ๋ฌธ์ž์—ด์„ ๊ฐ€๋Šฅํ•œ ์กฐํ•ฉ์œผ๋กœ ๋‚˜๋ˆ„๊ณ , ๊ทธ ์กฐํ•ฉ๋“ค์—์„œ ์ตœ๋Œ€๋ฅผ ์ฐพ์•„์•ผํ•œ๋‹ค. ๋‚˜๋Š” ๋ฌธ์ž์—ด์„ ๊ฐ€๋Šฅํ•œ ์กฐํ•ฉ์œผ๋กœ ๋‚˜๋ˆ„๋Š” ํ•จ์ˆ˜ search๋ฅผ ๋งŒ๋“ค์—ˆ๋‹ค. ์ธ์ž๊ฐ’์œผ๋กœ ๋“ค์–ด์˜ค๋Š” start๋Š” ๋ฌธ์ž์—ด ์กฐํ•ฉ์˜ ์‹œ์ž‘์„ ๋œปํ•˜๊ณ  cnt๋Š” ๋‚จ์€ ๋ฌธ์ž์—ด์„ ๋ช‡ ๋ถ€๋ถ„์œผ๋กœ ๋‚˜๋ˆŒ ๊ฒƒ์ธ์ง€๋ฅผ ๋„˜๊ฒจ์ฃผ๋„๋ก ํ–ˆ๋‹ค. global ๋ณ€์ˆ˜ set์„ ์‚ฌ์šฉํ•ด์„œ ์ €์žฅํ•˜๊ณ  ์ค‘๋ณต์„ ํ—ˆ์šฉํ•˜์ง€ ์•Š๋„๋ก ํ–ˆ๋‹ค. cal ํ•จ์ˆ˜์—์„œ๋Š” ๋ฌธ์ž์—ด ์กฐํ•ฉ๋“ค์—์„œ ์ตœ๋Œ€๊ฐ’์„ ๊ณ„์‚ฐํ•˜๋„๋ก ํ–ˆ๋‹ค. start์™€ cnt๋Š” search ํ•จ์ˆ˜์™€ ๋˜‘๊ฐ™๊ณ , P๋Š” ๋ฌธ์ž์—ด์„ ์ž„์‹œ๋กœ ์ €์žฅํ•˜๋Š” ๋ฐฐ์—ด์ด๋‹ค. ์ดํ›„ main ์—์„œ๋Š” ๋ฌธ์ž..

728x90