๋ฌธ์ ์ค๋ช
์ธ ์ฐจ๋ก์ ์ฝ๋ฉ ํ ์คํธ์ ๋ ์ฐจ๋ก์ ๋ฉด์ ์ด๋ผ๋ ๊ธฐ๋๊ธด ๋ธ๋ผ์ธ๋ ๊ณต์ฑ๋ฅผ ๋ฌด์ฌํ ํต๊ณผํด ์นด์นด์ค์ ์ ์ฌํ ๋ฌด์ง๋ ํ์ผ ์ ์ฅ์ ์๋ฒ ๊ด๋ฆฌ๋ฅผ ๋งก๊ฒ ๋์๋ค.
์ ์ฅ์ ์๋ฒ์๋ ํ๋ก๊ทธ๋จ์ ๊ณผ๊ฑฐ ๋ฒ์ ์ ๋ชจ๋ ๋ด๊ณ ์์ด, ์ด๋ฆ ์์ผ๋ก ์ ๋ ฌ๋ ํ์ผ ๋ชฉ๋ก์ ๋ณด๊ธฐ๊ฐ ๋ถํธํ๋ค. ํ์ผ์ ์ด๋ฆ ์์ผ๋ก ์ ๋ ฌํ๋ฉด ๋์ค์ ๋ง๋ค์ด์ง ver-10.zip์ด ver-9.zip๋ณด๋ค ๋จผ์ ํ์๋๊ธฐ ๋๋ฌธ์ด๋ค.
๋ฒ์ ๋ฒํธ ์ธ์๋ ์ซ์๊ฐ ํฌํจ๋ ํ์ผ ๋ชฉ๋ก์ ์ฌ๋ฌ ๋ฉด์์ ๊ด๋ฆฌํ๊ธฐ ๋ถํธํ๋ค. ์์ปจ๋ ํ์ผ ๋ชฉ๋ก์ด ["img12.png", "img10.png", "img2.png", "img1.png"]์ผ ๊ฒฝ์ฐ, ์ผ๋ฐ์ ์ธ ์ ๋ ฌ์ ["img1.png", "img10.png", "img12.png", "img2.png"] ์์ด ๋์ง๋ง, ์ซ์ ์์ผ๋ก ์ ๋ ฌ๋ ["img1.png", "img2.png", "img10.png", img12.png"] ์์ด ํจ์ฌ ์์ฐ์ค๋ฝ๋ค.
๋ฌด์ง๋ ๋จ์ํ ๋ฌธ์ ์ฝ๋ ์์ด ์๋, ํ์ผ๋ช ์ ํฌํจ๋ ์ซ์๋ฅผ ๋ฐ์ํ ์ ๋ ฌ ๊ธฐ๋ฅ์ ์ ์ฅ์ ๊ด๋ฆฌ ํ๋ก๊ทธ๋จ์ ๊ตฌํํ๊ธฐ๋ก ํ๋ค.
์์ค ํ์ผ ์ ์ฅ์์ ์ ์ฅ๋ ํ์ผ๋ช ์ 100 ๊ธ์ ์ด๋ด๋ก, ์๋ฌธ ๋์๋ฌธ์, ์ซ์, ๊ณต๋ฐฑ(" "), ๋ง์นจํ("."), ๋นผ๊ธฐ ๋ถํธ("-")๋ง์ผ๋ก ์ด๋ฃจ์ด์ ธ ์๋ค. ํ์ผ๋ช ์ ์๋ฌธ์๋ก ์์ํ๋ฉฐ, ์ซ์๋ฅผ ํ๋ ์ด์ ํฌํจํ๊ณ ์๋ค.
ํ์ผ๋ช ์ ํฌ๊ฒ HEAD, NUMBER, TAIL์ ์ธ ๋ถ๋ถ์ผ๋ก ๊ตฌ์ฑ๋๋ค.
- HEAD๋ ์ซ์๊ฐ ์๋ ๋ฌธ์๋ก ์ด๋ฃจ์ด์ ธ ์์ผ๋ฉฐ, ์ต์ํ ํ ๊ธ์ ์ด์์ด๋ค.
- NUMBER๋ ํ ๊ธ์์์ ์ต๋ ๋ค์ฏ ๊ธ์ ์ฌ์ด์ ์ฐ์๋ ์ซ์๋ก ์ด๋ฃจ์ด์ ธ ์์ผ๋ฉฐ, ์์ชฝ์ 0์ด ์ฌ ์ ์๋ค. 0๋ถํฐ 99999 ์ฌ์ด์ ์ซ์๋ก, 00000์ด๋ 0101 ๋ฑ๋ ๊ฐ๋ฅํ๋ค.
- TAIL์ ๊ทธ ๋๋จธ์ง ๋ถ๋ถ์ผ๋ก, ์ฌ๊ธฐ์๋ ์ซ์๊ฐ ๋ค์ ๋ํ๋ ์๋ ์์ผ๋ฉฐ, ์๋ฌด ๊ธ์๋ ์์ ์ ์๋ค.
![](https://blog.kakaocdn.net/dn/dBHf9G/btrL1zXjNRa/T6HtYX7yGBP0FW1UJkm1Vk/img.png)
ํ์ผ๋ช ์ ์ธ ๋ถ๋ถ์ผ๋ก ๋๋ ํ, ๋ค์ ๊ธฐ์ค์ ๋ฐ๋ผ ํ์ผ๋ช ์ ์ ๋ ฌํ๋ค.
- ํ์ผ๋ช ์ ์ฐ์ HEAD ๋ถ๋ถ์ ๊ธฐ์ค์ผ๋ก ์ฌ์ ์์ผ๋ก ์ ๋ ฌํ๋ค. ์ด๋, ๋ฌธ์์ด ๋น๊ต ์ ๋์๋ฌธ์ ๊ตฌ๋ถ์ ํ์ง ์๋๋ค. MUZI์ muzi, MuZi๋ ์ ๋ ฌ ์์ ๊ฐ์ ์์๋ก ์ทจ๊ธ๋๋ค.
- ํ์ผ๋ช ์ HEAD ๋ถ๋ถ์ด ๋์๋ฌธ์ ์ฐจ์ด ์ธ์๋ ๊ฐ์ ๊ฒฝ์ฐ, NUMBER์ ์ซ์ ์์ผ๋ก ์ ๋ ฌํ๋ค. 9 < 10 < 0011 < 012 < 13 < 014 ์์ผ๋ก ์ ๋ ฌ๋๋ค. ์ซ์ ์์ 0์ ๋ฌด์๋๋ฉฐ, 012์ 12๋ ์ ๋ ฌ ์์ ๊ฐ์ ๊ฐ์ ๊ฐ์ผ๋ก ์ฒ๋ฆฌ๋๋ค.
- ๋ ํ์ผ์ HEAD ๋ถ๋ถ๊ณผ, NUMBER์ ์ซ์๋ ๊ฐ์ ๊ฒฝ์ฐ, ์๋ ์ ๋ ฅ์ ์ฃผ์ด์ง ์์๋ฅผ ์ ์งํ๋ค. MUZI01.zip๊ณผ muzi1.png๊ฐ ์ ๋ ฅ์ผ๋ก ๋ค์ด์ค๋ฉด, ์ ๋ ฌ ํ์๋ ์ ๋ ฅ ์ ์ฃผ์ด์ง ๋ ํ์ผ์ ์์๊ฐ ๋ฐ๋์ด์๋ ์ ๋๋ค.
๋ฌด์ง๋ฅผ ๋์ ํ์ผ๋ช ์ ๋ ฌ ํ๋ก๊ทธ๋จ์ ๊ตฌํํ๋ผ.
์ ๋ ฅ ํ์
์ ๋ ฅ์ผ๋ก ๋ฐฐ์ด files๊ฐ ์ฃผ์ด์ง๋ค.
- files๋ 1000 ๊ฐ ์ดํ์ ํ์ผ๋ช ์ ํฌํจํ๋ ๋ฌธ์์ด ๋ฐฐ์ด์ด๋ค.
- ๊ฐ ํ์ผ๋ช ์ 100 ๊ธ์ ์ดํ ๊ธธ์ด๋ก, ์๋ฌธ ๋์๋ฌธ์, ์ซ์, ๊ณต๋ฐฑ(" "), ๋ง์นจํ("."), ๋นผ๊ธฐ ๋ถํธ("-")๋ง์ผ๋ก ์ด๋ฃจ์ด์ ธ ์๋ค. ํ์ผ๋ช ์ ์๋ฌธ์๋ก ์์ํ๋ฉฐ, ์ซ์๋ฅผ ํ๋ ์ด์ ํฌํจํ๊ณ ์๋ค.
- ์ค๋ณต๋ ํ์ผ๋ช ์ ์์ผ๋, ๋์๋ฌธ์๋ ์ซ์ ์๋ถ๋ถ์ 0 ์ฐจ์ด๊ฐ ์๋ ๊ฒฝ์ฐ๋ ํจ๊ป ์ฃผ์ด์ง ์ ์๋ค. (muzi1.txt, MUZI1.txt, muzi001.txt, muzi1.TXT๋ ํจ๊ป ์ ๋ ฅ์ผ๋ก ์ฃผ์ด์ง ์ ์๋ค.)
์ถ๋ ฅ ํ์
์ ๊ธฐ์ค์ ๋ฐ๋ผ ์ ๋ ฌ๋ ๋ฐฐ์ด์ ์ถ๋ ฅํ๋ค.
์ ์ถ๋ ฅ ์์
์
๋ ฅ: ["img12.png", "img10.png", "img02.png", "img1.png", "IMG01.GIF", "img2.JPG"]
์ถ๋ ฅ: ["img1.png", "IMG01.GIF", "img02.png", "img2.JPG", "img10.png", "img12.png"]
์
๋ ฅ: ["F-5 Freedom Fighter", "B-50 Superfortress", "A-10 Thunderbolt II", "F-14 Tomcat"]
์ถ๋ ฅ: ["A-10 Thunderbolt II", "B-50 Superfortress", "F-5 Freedom Fighter", "F-14 Tomcat"]
ํ์ด ์ฝ๋
from collections import deque
def solution(files):
answer = []
file_array = []
for idx, f in enumerate(files):
file = [f, '', '', '', idx]
queue = deque(f)
# fill head
while queue:
if queue[0].isdigit():
break
else:
temp = queue.popleft()
if temp.isalpha():
file[1] += temp.lower()
else:
file[1] += temp
# fill number
cnt = 0
while queue:
if cnt >= 5:
break
if queue[0].isdigit():
file[2] += queue.popleft()
cnt += 1
else:
break
# fill tail
file[3] += ''.join(queue)
file_array.append(file)
file_array.sort(key = lambda x: (x[1], int(x[2]), x[4]))
for f in file_array:
answer.append(''.join(f[0]))
return answer
๊ตฌํ ๋ฌธ์ ์ด๊ณ , ์ ๋ ฌ๊ณผ ํ ์๋ฃ๊ตฌ์กฐ๋ฅผ ์ฌ์ฉํด ํ์ดํ๋ค.
์ฐ์ ์ ๋ ฌ์ ํด์ผ ํ์ง๋ง, ๊ธฐ์ค์ด ๋๋ ํค๊ฐ head, number, tail์ด๊ณ , ์ค์ ์ ๋ ฌ๋์ด์ผ ํ๋ ๊ฐ์ files์ ๋ค์ด์๋ ์์์ด๋ค.
๋ฐ๋ผ์ file = [๊ธฐ์กด ํ์ผ, HEAD, NUMBER, TAIL, ๊ธฐ์กด์ ๋ค์ด์๋ ์๋ฒ]์ผ๋ก ์์ ์ฑ์์ค๋ค.
์์ ์ฑ์์ฃผ๋ ๊ณผ์ ์, ํ ๋ด๋ถ์ ๊ธฐ์กด ํ์ผ ์ด๋ฆ์ ์ง์ด ๋ฃ๊ณ ์ซ์๊ฐ ๋์ค๊ธฐ ์ ๊น์ง๋ฅผ HEAD์ ์ ์ฅํ๋ค.
HEAD์ ์ ์ฅํ ๋๋, ์ ๋ ฌ ์ ๋์๋ฌธ์ ๊ตฌ๋ถ์ ํ์ง ์์ผ๋ฏ๋ก islower() ํจ์๋ฅผ ํตํด ๋ชจ๋ ์๋ฌธ์ ํค ๊ฐ์ ๊ฐ๋๋ก ํ๋ค.
๊ทธ ์ดํ์ ์ซ์๊ฐ ์๋ ๋ฌธ์๊ฐ ๋์ฌ ๋๊น์ง ํน์ ์ซ์์ฌ๋ 5์๋ฆฌ๊น์ง ๋์ด NUMBER์ ์ ์ฅํ๋ค.
๋๋จธ์ง ํ์ ๋จ์ ๊ฒ์ TAIL์ ์ ์ฅํ๋ค.
์ด์ ์ด๊ฒ๋ค์ด ์ ๋ฆฌ๋ ์ด์ฐจ์ ๋ฆฌ์คํธ(file_array)๋ฅผ sorting ํ๋ค.
ํค ๊ฐ์ ์ฐ์ HEAD์ผ๋ก ์ ๋ ฌ, ๊ทธ ์์์ ์ซ์ ๊ธฐ์ค NUMBER์ผ๋ก ์ ๋ ฌ, ๊ทธ ์์์ ๋ค์ด์๋ ์๋ฒ ์์ผ๋ก ์ ๋ ฌํ๋ค.
์ด์ ๊ฐ ๋ฐฐ์ด์ 0๋ฒ ์ธ๋ฑ์ค ์์์๋ ๊ธฐ์กด ํ์ผ ์ด๋ฆ์ด ๋ค์ด์์ผ๋ฏ๋ก ์ด๊ฒ๋ง ๋นผ๋ด์ด ๋ฆฌํดํ๋ฉด ๋๋ค.
'๐ ์ฝ๋ฉํ ์คํธ ๋๋น : PS' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[ํ๋ก๊ทธ๋๋จธ์ค] ๊ฒ์ ๋งต ์ต๋จ๊ฑฐ๋ฆฌ (level2, python) (1) | 2022.09.13 |
---|---|
[ํ๋ก๊ทธ๋๋จธ์ค] ๋ชจ์์ฌ์ (level2, python) (1) | 2022.09.13 |
[ํ๋ก๊ทธ๋๋จธ์ค] ๋ฐฉ๋ฌธ ๊ธธ์ด (level2, python) (0) | 2022.09.13 |
[ํ๋ก๊ทธ๋๋จธ์ค] ์คํฌํธ๋ฆฌ (level2, python) (0) | 2022.09.13 |
[ํ๋ก๊ทธ๋๋จธ์ค] ๋ ๋ฐ๋จน๊ธฐ (level2, python) (0) | 2022.09.13 |