๐กsolutions )
โ ์ด๋ฒ ๋ฌธ์ ๋ ์ํํด์ผ ํ๋ ๋ชจ๋ ๊ณผ์ ์ด ๋์์๋ ์๋ฎฌ๋ ์ด์ ๋ฌธ์ . ์ฃผ์ด์ง ๊ฒ๋ค๋ง ๊ผผ๊ผผํ ์ ์ฑ๊ฒจ์ ๋ก์ง์ ์ง๋ฉด ๋ง์ถ ์ ์๋ ๋ฌธ์
โ ์ด 3๊ฐ์ง ํจ์๋ฅผ ๊ตฌํ
โ ๋ฌธ์ ์์ ์ฃผ์ด์ง ๊ณผ์ ์ ์ํํ solution ํจ์
โก๊ท ํ ์กํ ๋ฌธ์์ด์ธ์ง ํ๋ณํ์ฌ u, v ๋ฌธ์์ด๋ก ๋ถ๋ฆฌํ isBalance ํจ์
โข์ฌ๋ฐ๋ฅธ ๋ฌธ์์ด์ธ์ง ํ๋ณํ isRight ํจ์
๐ซcode )
def solution(p):
result = ""
if p == "":
return p
# ์ ์ฒด๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด๋ฉด
elif isRight(p) == True:
return p
else:
# u, v๋ก ๋ฌธ์์ด ๋๋๊ธฐ
u, v = isBalance(p)
# u๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด๋ฉด
if isRight(u) == True:
result += u
result += solution(v)
return result
# u๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด ์๋๋ฉด False
else:
result += "("
result += solution(v)
result += ")"
tmp = ""
for i in u[1:-1]:
if i == "(":
tmp += ")"
else:
tmp += "("
result += tmp
return result
# ๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด์ธ์ง ํ๋ณํ์ฌ, u๋ v ๋ฌธ์์ด ๋๋๊ธฐ
def isBalance(p):
left_cnt = 0
right_cnt = 0
for i in p:
if i == "(":
left_cnt += 1
else:
right_cnt += 1
if right_cnt != 0 and left_cnt == right_cnt:
# u,v๋ก ๋ฌธ์์ด ๋์ด์ฃผ๊ธฐ
idx = left_cnt + right_cnt
u, v = p[0:idx], p[idx:]
return u, v
# ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ธ์ง ํ๋ณ
def isRight(p):
tmp = []
for i in p:
if i == "(":
tmp.append(i)
else:
if len(tmp) == 0:
return False
tmp.pop()
if len(tmp) > 0:
return False
else:
return True
๐ description )
๋ฌธ์ ์ถ์ฒ : https://programmers.co.kr/learn/courses/30/lessons/60058?language=python3
์ฝ๋ฉํ ์คํธ ์ฐ์ต - ๊ดํธ ๋ณํ
์นด์นด์ค์ ์ ์ ๊ฐ๋ฐ์๋ก ์ ์ฌํ ์ฝ์ ์ ๋ฐฐ ๊ฐ๋ฐ์๋ก๋ถํฐ ๊ฐ๋ฐ์ญ๋ ๊ฐํ๋ฅผ ์ํด ๋ค๋ฅธ ๊ฐ๋ฐ์๊ฐ ์์ฑํ ์์ค ์ฝ๋๋ฅผ ๋ถ์ํ์ฌ ๋ฌธ์ ์ ์ ๋ฐ๊ฒฌํ๊ณ ์์ ํ๋ผ๋ ์ ๋ฌด ๊ณผ์ ๋ฅผ ๋ฐ์์ต๋๋ค. ์์ค๋ฅผ ์ปด๏ฟฝ
programmers.co.kr
๋ฌธ์ ์ค๋ช
์นด์นด์ค์ ์ ์ ๊ฐ๋ฐ์๋ก ์ ์ฌํ ์ฝ์ ์ ๋ฐฐ ๊ฐ๋ฐ์๋ก๋ถํฐ ๊ฐ๋ฐ์ญ๋ ๊ฐํ๋ฅผ ์ํด ๋ค๋ฅธ ๊ฐ๋ฐ์๊ฐ ์์ฑํ ์์ค ์ฝ๋๋ฅผ ๋ถ์ํ์ฌ ๋ฌธ์ ์ ์ ๋ฐ๊ฒฌํ๊ณ ์์ ํ๋ผ๋ ์ ๋ฌด ๊ณผ์ ๋ฅผ ๋ฐ์์ต๋๋ค. ์์ค๋ฅผ ์ปดํ์ผํ์ฌ ๋ก๊ทธ๋ฅผ ๋ณด๋ ๋๋ถ๋ถ ์์ค ์ฝ๋ ๋ด ์์ฑ๋ ๊ดํธ๊ฐ ๊ฐ์๋ ๋ง์ง๋ง ์ง์ด ๋ง์ง ์์ ํํ๋ก ์์ฑ๋์ด ์ค๋ฅ๊ฐ ๋๋ ๊ฒ์ ์๊ฒ ๋์์ต๋๋ค.
์์ ํด์ผ ํ ์์ค ํ์ผ์ด ๋๋ฌด ๋ง์์ ๊ณ ๋ฏผํ๋ ์ฝ์ ์์ค ์ฝ๋์ ์์ฑ๋ ๋ชจ๋ ๊ดํธ๋ฅผ ๋ฝ์์ ์ฌ๋ฐ๋ฅธ ์์๋๋ก ๋ฐฐ์น๋ ๊ดํธ ๋ฌธ์์ด์ ์๋ ค์ฃผ๋ ํ๋ก๊ทธ๋จ์ ๋ค์๊ณผ ๊ฐ์ด ๊ฐ๋ฐํ๋ ค๊ณ ํฉ๋๋ค.์ฉ์ด์ ์ ์
'(' ์ ')' ๋ก๋ง ์ด๋ฃจ์ด์ง ๋ฌธ์์ด์ด ์์ ๊ฒฝ์ฐ, '(' ์ ๊ฐ์์ ')' ์ ๊ฐ์๊ฐ ๊ฐ๋ค๋ฉด ์ด๋ฅผ ๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด์ด๋ผ๊ณ ๋ถ๋ฆ ๋๋ค.
๊ทธ๋ฆฌ๊ณ ์ฌ๊ธฐ์ '('์ ')'์ ๊ดํธ์ ์ง๋ ๋ชจ๋ ๋ง์ ๊ฒฝ์ฐ์๋ ์ด๋ฅผ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด๋ผ๊ณ ๋ถ๋ฆ ๋๋ค.
์๋ฅผ ๋ค์ด, "(()))("์ ๊ฐ์ ๋ฌธ์์ด์ ๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด ์ด์ง๋ง ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ ์๋๋๋ค.
๋ฐ๋ฉด์ "(())()"์ ๊ฐ์ ๋ฌธ์์ด์ ๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด ์ด๋ฉด์ ๋์์ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด ์ ๋๋ค.'(' ์ ')' ๋ก๋ง ์ด๋ฃจ์ด์ง ๋ฌธ์์ด w๊ฐ ๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด ์ด๋ผ๋ฉด ๋ค์๊ณผ ๊ฐ์ ๊ณผ์ ์ ํตํด ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด๋ก ๋ณํํ ์ ์์ต๋๋ค.
1. ์ ๋ ฅ์ด ๋น ๋ฌธ์์ด์ธ ๊ฒฝ์ฐ, ๋น ๋ฌธ์์ด์ ๋ฐํํฉ๋๋ค. 2. ๋ฌธ์์ด w๋ฅผ ๋ "๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด" u, v๋ก ๋ถ๋ฆฌํฉ๋๋ค. ๋จ, u๋ "๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด"๋ก ๋ ์ด์ ๋ถ๋ฆฌํ ์ ์์ด์ผ ํ๋ฉฐ, v๋ ๋น ๋ฌธ์์ด์ด ๋ ์ ์์ต๋๋ค. 3. ๋ฌธ์์ด u๊ฐ "์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด" ์ด๋ผ๋ฉด ๋ฌธ์์ด v์ ๋ํด 1๋จ๊ณ๋ถํฐ ๋ค์ ์ํํฉ๋๋ค. 3-1. ์ํํ ๊ฒฐ๊ณผ ๋ฌธ์์ด์ u์ ์ด์ด ๋ถ์ธ ํ ๋ฐํํฉ๋๋ค. 4. ๋ฌธ์์ด u๊ฐ "์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด"์ด ์๋๋ผ๋ฉด ์๋ ๊ณผ์ ์ ์ํํฉ๋๋ค. 4-1. ๋น ๋ฌธ์์ด์ ์ฒซ ๋ฒ์งธ ๋ฌธ์๋ก '('๋ฅผ ๋ถ์ ๋๋ค. 4-2. ๋ฌธ์์ด v์ ๋ํด 1๋จ๊ณ๋ถํฐ ์ฌ๊ท์ ์ผ๋ก ์ํํ ๊ฒฐ๊ณผ ๋ฌธ์์ด์ ์ด์ด ๋ถ์ ๋๋ค. 4-3. ')'๋ฅผ ๋ค์ ๋ถ์ ๋๋ค. 4-4. u์ ์ฒซ ๋ฒ์งธ์ ๋ง์ง๋ง ๋ฌธ์๋ฅผ ์ ๊ฑฐํ๊ณ , ๋๋จธ์ง ๋ฌธ์์ด์ ๊ดํธ ๋ฐฉํฅ์ ๋ค์ง์ด์ ๋ค์ ๋ถ์ ๋๋ค. 4-5. ์์ฑ๋ ๋ฌธ์์ด์ ๋ฐํํฉ๋๋ค.
๊ท ํ์กํ ๊ดํธ ๋ฌธ์์ด p๊ฐ ๋งค๊ฐ๋ณ์๋ก ์ฃผ์ด์ง ๋, ์ฃผ์ด์ง ์๊ณ ๋ฆฌ์ฆ์ ์ํํด ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด๋ก ๋ณํํ ๊ฒฐ๊ณผ๋ฅผ return ํ๋๋ก solution ํจ์๋ฅผ ์์ฑํด ์ฃผ์ธ์.
๋งค๊ฐ๋ณ์ ์ค๋ช
- p๋ '(' ์ ')' ๋ก๋ง ์ด๋ฃจ์ด์ง ๋ฌธ์์ด์ด๋ฉฐ ๊ธธ์ด๋ 2 ์ด์ 1,000 ์ดํ์ธ ์ง์์ ๋๋ค.
- ๋ฌธ์์ด p๋ฅผ ์ด๋ฃจ๋ '(' ์ ')' ์ ๊ฐ์๋ ํญ์ ๊ฐ์ต๋๋ค.
- ๋ง์ฝ p๊ฐ ์ด๋ฏธ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด๋ผ๋ฉด ๊ทธ๋๋ก return ํ๋ฉด ๋ฉ๋๋ค.
์ ์ถ๋ ฅ ์
p result
"(()())()" "(()())()" ")(" "()" "()))((()" "()(())()"
์ ์ถ๋ ฅ ์ #1
์ด๋ฏธ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด ์ ๋๋ค.์ ์ถ๋ ฅ ์ #2
- ๋ ๋ฌธ์์ด u, v๋ก ๋ถ๋ฆฌํฉ๋๋ค.
- u = ")("
- v = ""
- u๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด ์๋๋ฏ๋ก ๋ค์๊ณผ ๊ฐ์ด ์๋ก์ด ๋ฌธ์์ด์ ๋ง๋ญ๋๋ค.
- v์ ๋ํด 1๋จ๊ณ๋ถํฐ ์ฌ๊ท์ ์ผ๋ก ์ํํ๋ฉด ๋น ๋ฌธ์์ด์ด ๋ฐํ๋ฉ๋๋ค.
- u์ ์๋ค ๋ฌธ์๋ฅผ ์ ๊ฑฐํ๊ณ , ๋๋จธ์ง ๋ฌธ์์ ๊ดํธ ๋ฐฉํฅ์ ๋ค์ง์ผ๋ฉด ""์ด ๋ฉ๋๋ค.
- ๋ฐ๋ผ์ ์์ฑ๋๋ ๋ฌธ์์ด์ "(" + "" + ")" + ""์ด๋ฉฐ, ์ต์ข ์ ์ผ๋ก "()"๋ก ๋ณํ๋ฉ๋๋ค.
์ ์ถ๋ ฅ ์ #3
- ๋ ๋ฌธ์์ด u, v๋ก ๋ถ๋ฆฌํฉ๋๋ค.
- u = "()"
- v = "))((()"
- ๋ฌธ์์ด u๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด๋ฏ๋ก ๊ทธ๋๋ก ๋๊ณ , v์ ๋ํด ์ฌ๊ท์ ์ผ๋ก ์ํํฉ๋๋ค.
- ๋ค์ ๋ ๋ฌธ์์ด u, v๋ก ๋ถ๋ฆฌํฉ๋๋ค.
- u = "))(("
- v = "()"
- u๊ฐ ์ฌ๋ฐ๋ฅธ ๊ดํธ ๋ฌธ์์ด์ด ์๋๋ฏ๋ก ๋ค์๊ณผ ๊ฐ์ด ์๋ก์ด ๋ฌธ์์ด์ ๋ง๋ญ๋๋ค.
- v์ ๋ํด 1๋จ๊ณ๋ถํฐ ์ฌ๊ท์ ์ผ๋ก ์ํํ๋ฉด "()"์ด ๋ฐํ๋ฉ๋๋ค.
- u์ ์๋ค ๋ฌธ์๋ฅผ ์ ๊ฑฐํ๊ณ , ๋๋จธ์ง ๋ฌธ์์ ๊ดํธ ๋ฐฉํฅ์ ๋ค์ง์ผ๋ฉด "()"์ด ๋ฉ๋๋ค.
- ๋ฐ๋ผ์ ์์ฑ๋๋ ๋ฌธ์์ด์ "(" + "()" + ")" + "()"์ด๋ฉฐ, ์ต์ข ์ ์ผ๋ก "(())()"๋ฅผ ๋ฐํํฉ๋๋ค.
- ์ฒ์์ ๊ทธ๋๋ก ๋ ๋ฌธ์์ด์ ๋ฐํ๋ ๋ฌธ์์ด์ ์ด์ด ๋ถ์ด๋ฉด "()" + "(())()" = "()(())()"๊ฐ ๋ฉ๋๋ค.