μ•Œκ³ λ¦¬μ¦˜/κ·Έλž˜ν”„

[λ°±μ€€ 14888 πŸ₯ˆ] μ—°μ‚°μž λΌμ›Œλ„£κΈ°

1eehyunji 2023. 8. 31. 01:58

문제

N개의 수둜 이루어진 μˆ˜μ—΄ A1, A2, ..., AN이 μ£Όμ–΄μ§„λ‹€. 또, μˆ˜μ™€ 수 사이에 λΌμ›Œλ„£μ„ 수 μžˆλŠ” N-1개의 μ—°μ‚°μžκ°€ μ£Όμ–΄μ§„λ‹€. μ—°μ‚°μžλŠ” λ§μ…ˆ(+), λΊ„μ…ˆ(-), κ³±μ…ˆ(×), λ‚˜λˆ—μ…ˆ(÷)으둜만 이루어져 μžˆλ‹€.

μš°λ¦¬λŠ” μˆ˜μ™€ 수 사이에 μ—°μ‚°μžλ₯Ό ν•˜λ‚˜μ”© λ„£μ–΄μ„œ, μˆ˜μ‹μ„ ν•˜λ‚˜ λ§Œλ“€ 수 μžˆλ‹€. μ΄λ•Œ, μ£Όμ–΄μ§„ 수의 μˆœμ„œλ₯Ό λ°”κΎΈλ©΄ μ•ˆ λœλ‹€.

예λ₯Ό λ“€μ–΄, 6개의 수둜 이루어진 μˆ˜μ—΄μ΄ 1, 2, 3, 4, 5, 6이고, μ£Όμ–΄μ§„ μ—°μ‚°μžκ°€ λ§μ…ˆ(+) 2개, λΊ„μ…ˆ(-) 1개, κ³±μ…ˆ(×) 1개, λ‚˜λˆ—μ…ˆ(÷) 1개인 κ²½μš°μ—λŠ” 총 60κ°€μ§€μ˜ 식을 λ§Œλ“€ 수 μžˆλ‹€. 예λ₯Ό λ“€μ–΄, μ•„λž˜μ™€ 같은 식을 λ§Œλ“€ 수 μžˆλ‹€.

  • 1+2+3-4×5÷6
  • 1÷2+3+4-5×6
  • 1+2÷3×4-5+6
  • 1÷2×3-4+5+6

μ‹μ˜ 계산은 μ—°μ‚°μž μš°μ„  μˆœμœ„λ₯Ό λ¬΄μ‹œν•˜κ³  μ•žμ—μ„œλΆ€ν„° μ§„ν–‰ν•΄μ•Ό ν•œλ‹€. 또, λ‚˜λˆ—μ…ˆμ€ μ •μˆ˜ λ‚˜λˆ—μ…ˆμœΌλ‘œ λͺ«λ§Œ μ·¨ν•œλ‹€. 음수λ₯Ό μ–‘μˆ˜λ‘œ λ‚˜λˆŒ λ•ŒλŠ” C++14의 기쀀을 λ”°λ₯Έλ‹€. 즉, μ–‘μˆ˜λ‘œ λ°”κΎΌ λ’€ λͺ«μ„ μ·¨ν•˜κ³ , κ·Έ λͺ«μ„ 음수둜 λ°”κΎΌ 것과 κ°™λ‹€. 이에 λ”°λΌμ„œ, μœ„μ˜ 식 4개의 κ²°κ³Όλ₯Ό 계산해보면 μ•„λž˜μ™€ κ°™λ‹€.

  • 1+2+3-4×5÷6 = 1
  • 1÷2+3+4-5×6 = 12
  • 1+2÷3×4-5+6 = 5
  • 1÷2×3-4+5+6 = 7

N개의 μˆ˜μ™€ N-1개의 μ—°μ‚°μžκ°€ μ£Όμ–΄μ‘Œμ„ λ•Œ, λ§Œλ“€ 수 μžˆλŠ” μ‹μ˜ κ²°κ³Όκ°€ μ΅œλŒ€μΈ 것과 μ΅œμ†ŒμΈ 것을 κ΅¬ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

μž…λ ₯

첫째 쀄에 수의 개수 N(2 ≤ N ≤ 11)κ°€ μ£Όμ–΄μ§„λ‹€. λ‘˜μ§Έ μ€„μ—λŠ” A1, A2, ..., AN이 μ£Όμ–΄μ§„λ‹€. (1 ≤ Ai ≤ 100) μ…‹μ§Έ μ€„μ—λŠ” 합이 N-1인 4개의 μ •μˆ˜κ°€ μ£Όμ–΄μ§€λŠ”λ°, μ°¨λ‘€λŒ€λ‘œ λ§μ…ˆ(+)의 개수, λΊ„μ…ˆ(-)의 개수, κ³±μ…ˆ(×)의 개수, λ‚˜λˆ—μ…ˆ(÷)의 κ°œμˆ˜μ΄λ‹€.

좜λ ₯

첫째 쀄에 λ§Œλ“€ 수 μžˆλŠ” μ‹μ˜ 결과의 μ΅œλŒ“κ°’μ„, λ‘˜μ§Έ μ€„μ—λŠ” μ΅œμ†Ÿκ°’μ„ 좜λ ₯ν•œλ‹€. μ—°μ‚°μžλ₯Ό μ–΄λ–»κ²Œ λΌμ›Œλ„£μ–΄λ„ 항상 -10얡보닀 ν¬κ±°λ‚˜ κ°™κ³ , 10얡보닀 μž‘κ±°λ‚˜ 같은 κ²°κ³Όκ°€ λ‚˜μ˜€λŠ” μž…λ ₯만 μ£Όμ–΄μ§„λ‹€. λ˜ν•œ, μ•žμ—μ„œλΆ€ν„° κ³„μ‚°ν–ˆμ„ λ•Œ, 쀑간에 κ³„μ‚°λ˜λŠ” μ‹μ˜ 결과도 항상 -10얡보닀 ν¬κ±°λ‚˜ κ°™κ³ , 10얡보닀 μž‘κ±°λ‚˜ κ°™λ‹€.

문제 풀이

import sys

n=int(sys.stdin.readline().strip())
numbers=list(map(int, sys.stdin.readline().strip().split(' ')))
opr=list(map(int, sys.stdin.readline().strip().split(' ')))

maxans=int(-1e9)
minans=int(1e9)
def dfs(cur,idx):
    global maxans, minans, n
    if idx==n:
        maxans=max(maxans, cur)
        minans=min(minans, cur)
        return
    # λ”ν•˜κΈ°
    if opr[0]>0:
        opr[0]-=1
        dfs(cur+numbers[idx], idx+1)
        opr[0]+=1
    # λΉΌκΈ°
    if opr[1]>0:
        opr[1]-=1
        dfs(cur-numbers[idx], idx+1)
        opr[1]+=1
    # κ³±ν•˜κΈ°
    if opr[2]>0:
        opr[2]-=1
        dfs(cur*numbers[idx], idx+1)
        opr[2]+=1
    # λ‚˜λˆ„κΈ°
    if opr[3]>0:
        opr[3]-=1
        if cur<0:
            cur=-cur
            dfs(-(cur//numbers[idx]), idx+1)
        else:
            dfs(cur//numbers[idx], idx+1)
        opr[3]+=1

dfs(numbers[0], 1)

print(maxans)
print(minans)
  • dfsλ₯Ό μ΄μš©ν•œ μ™„μ „ νƒμƒ‰μœΌλ‘œ ν’€μ—ˆλ‹€.
  • opr 배열에 μ €μž₯된 μ—°μ‚°μžμ˜ 개수 정보λ₯Ό λ”ν•˜κΈ°λ₯Ό λ„£λŠ” 경우 opr[0]을 -1ν•˜κ³ , dfsλ₯Ό λŒλ©΄μ„œ λ§ˆμ§€λ§‰ μˆ˜κΉŒμ§€ λͺ¨λ‘ νƒμƒ‰ν•˜λ©΄ ν•΄λ‹Ή dfsλ₯Ό λΉ μ Έλ‚˜μ˜€λ©΄ λ‹€μ‹œ opr[0]을 +1ν–ˆλ‹€.
  • μ—¬κΈ°μ„œ μ£Όμ˜ν•  점은 음수λ₯Ό μ–‘μˆ˜λ‘œ λ‚˜λˆ„λŠ” 경우 C++14 λ₯Ό κΈ°μ€€μœΌλ‘œ ν•œλ‹€κ³  λ˜μ–΄ μžˆλŠ”λ°, μ΄λŠ” μ–‘μˆ˜λ‘œ λ°”κΎΌ λ’€ λͺ«μ„ μ·¨ν•˜κ³ , κ·Έ λͺ«μ„ 음수둜 λ°”κΎΌ 것과 κ°™λ‹€.
    • 이 뢀뢄을 κ΅¬ν˜„ν•˜κΈ° μœ„ν•΄ λ‚˜λˆ„κΈ° 연산을 ν•΄μ£ΌλŠ” λΆ€λΆ„μ—μ„œ cur이 음수이면 λ‹¨μˆœνžˆ μ •μˆ˜ λ‚˜λˆ—μ…ˆμ„ ν•΄μ£ΌλŠ” 것이 μ•„λ‹ˆλΌ, μœ„μ— λͺ…μ‹œν•œ λ°©λ²•μœΌλ‘œ λ‚˜λˆ„κΈ° 연산을 ν–ˆλ‹€.
  • 또 μ£Όμ˜ν•  점은 μ²˜μŒμ— minans와 maxansλ₯Ό 각각 1e9, -1e9둜 μ΄ˆκΈ°ν™”ν–ˆμ—ˆλŠ”λ°, λ§Œμ•½ μ΅œμ†Ÿκ°’μ΄ 1000000000일 경우 초기 minans보닀 더 μž‘μ€ 값이라고 μΈμ‹ν•˜μ§€ μ•Šμ•„μ„œ minansκ°€ κ·ΈλŒ€λ‘œ 1000000000.0 으둜 좜λ ₯λœλ‹€.
    • 이 λ¬Έμ œλŠ” μ—°μ‚° κ²°κ³Όκ°€ μ •μˆ˜μ—¬μ•Ό ν•˜κΈ° λ•Œλ¬Έμ— 이와 같은 μ†Œμˆ˜ ν˜•νƒœλŠ” intν˜•μœΌλ‘œ λ°”κΏ”μ€˜μ•Ό ν•œλ‹€.