πŸ‘©πŸ»‍πŸ’» 갓생 직μž₯인 λ‚¨λ°”μ˜€
article thumbnail

https://www.acmicpc.net/problem/14888

 

14888번: μ—°μ‚°μž λΌμ›Œλ„£κΈ°

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

www.acmicpc.net

문제

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얡보닀 μž‘κ±°λ‚˜ κ°™λ‹€.


문제 ν•΄κ²°

μ²˜μŒμ— 수의 μˆœμ„œλ₯Ό λ°”κΎΈλ©΄ μ•ˆλœλ‹€λŠ” 글을 λͺ» μ½μ–΄μ„œ,, κ½€λ‚˜ λ³΅μž‘ν•œ μ½”λ“œλ₯Ό μ§œλ‹€κ°€ 이게 싀버라고..? ν•˜λ©΄μ„œ λ‹€μ‹œ μ½μ–΄λ³΄λ‹ˆ μ£Όμ–΄μ§„ 수의 μˆœμ„œλ₯Ό λ°”κΎΈλ©΄ μ•ˆλœλ‹€.. 바보닀 글을 λ˜‘λ°”λ‘œ 읽자

 

κ·ΈλŸ¬λ‹ˆ 훨씬 κ°„λ‹¨ν•΄μ‘Œλ‹€. 수의 μˆœμ„œλŠ” μ •ν•΄μ Έμžˆκ³  μ—°μ‚°μžλ§Œ λ°”λ€Œλ©΄ 되기 λ•Œλ¬Έμ— DFS둜 ν’€μ—ˆλ‹€.

μ—°μ‚°μžλ§ˆλ‹€ caseλ₯Ό λ‚˜λˆ  μˆ˜ν–‰ν•œ 후에 μž¬κ·€ν˜ΈμΆœλ‘œ νƒμƒ‰ν•΄μ£Όμ—ˆλ‹€.

#μ—°μ‚°μž λΌμ›Œλ„£κΈ°

N = int(input())
A = list(map(int, input().split()))
cal = list(map(int, input().split())) # +, -, x, / μˆœμ„œ

maximum, minimum = -1e9, 1e9
#이 solution을 계속 λŒλ¦¬λ©΄μ„œ 계산 λλ‚˜λ©΄ max, min λ¦¬ν„΄ν•˜κ³  끝

def solution(cnt, sum, plus, minus, multiple, divide):
    global maximum, minimum
    if cnt == N:
        maximum = max(sum, maximum)
        minimum = min(sum, minimum)
        return

    if plus:
        solution(cnt+1, sum+A[cnt], plus-1, minus, multiple, divide)
    if minus:
        solution(cnt+1, sum-A[cnt], plus, minus-1, multiple, divide)
    if multiple:
        solution(cnt+1, sum*A[cnt], plus, minus, multiple-1, divide)
    if divide:
        solution(cnt+1, int(sum/A[cnt]), plus, minus, multiple, divide-1)

solution(1, A[0], cal[0], cal[1], cal[2], cal[3] )

print(maximum)
print(minimum)

μ²˜μŒμ— divide ν•˜λŠ” λΆ€λΆ„μ—μ„œ 생각없이

sum // A[cnt] λ₯Ό ν•΄μ£Όμ—ˆλŠ”λ° Testcase3λ²ˆμ—μ„œ λ°”λ‘œ 였λ₯˜κ°€ λ°œμƒν–ˆλ‹€. μ œμ•½μ‚¬ν•­μ— λ‚˜λˆ—μ…ˆμ— λŒ€ν•΄ 쑰건이 λ§Žμ•˜κΈ° λ•Œλ¬Έμ— λ‹€μ‹œ μ‚΄νŽ΄λ³΄λ‹ˆ,

즉, μ–‘μˆ˜λ‘œ λ°”κΎΌ λ’€ λͺ«μ„ μ·¨ν•˜κ³ , κ·Έ λͺ«μ„ 음수둜 λ°”κΎΌ 것과 κ°™λ‹€. 

둜 λ˜μ–΄μžˆλ‹€. 이런 κ²½μš°μ—

μœ„μ™€ 같은 차이가 생기기 λ•Œλ¬Έμ— int(sum/A[cnt]) 둜 λ³€κ²½ν•΄μ£Όλ‹ˆ 였λ₯˜ ν•΄κ²° μ™„ ! 

profile

πŸ‘©πŸ»‍πŸ’» 갓생 직μž₯인 λ‚¨λ°”μ˜€

@λ‚¨λ°”μ˜€