λ³Έλ¬Έ λ°”λ‘œκ°€κΈ°

Programming/Algorithm

[Kotlin] λ°±μ€€ 14888 - μ—°μ‚°μž λΌμ›Œλ„£κΈ°(μž¬κ·€μ™„μ „νƒμƒ‰ DFS, λ°±νŠΈλž˜ν‚Ή)

728x90
λ°˜μ‘ν˜•

문제

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

예제 μž…λ ₯ 1

2
5 6
0 0 1 0

예제 좜λ ₯ 1

30
30

예제 μž…λ ₯ 2

3
3 4 5
1 0 1 0

예제 좜λ ₯ 2

35
17

예제 μž…λ ₯ 3

6
1 2 3 4 5 6
2 1 1 1

예제 좜λ ₯ 3

54
-24

 

풀이

λͺ¨λ“  경우의 수λ₯Ό κ³„μ‚°ν•˜λŠ” 완전탐색
κΉŠμ΄μš°μ„ νƒμƒ‰(DFS)와 λ°±νŠΈλž˜ν‚Ή μ—°μŠ΅ 문제

 

μ½”λ“œ
import java.util.*

fun main() = with(System.`in`.bufferedReader()) {
	// μ—°μ‚¬μž λΌμ›Œλ„£κΈ°, μž¬κ·€μ—°μŠ΅
	val N = readLine().toInt()
	val nl = readLine().split(" ").map{it.toInt()}.toIntArray()
	val ol = readLine().split(" ").map{it.toInt()}.toIntArray()	// +, -, *, /
	var min = Int.MAX_VALUE
	var max = Int.MIN_VALUE
    
   	fun dfs(level: Int, currentValue: Int) {
        // μ΅œμ’… κΉŠμ΄μ—μ„œ κ²°κ³Όκ°’ λ„μΆœ
        if(level == N) {
            min = minOf(min, currentValue)
            max = maxOf(max, currentValue)

            return
        }
        
        // μ—°μ‚°μž 루프
        for(i in 0..3) {
            if(ol[i] > 0){
                ol[i]--	// μ—°μ‚°μž μ‚¬μš©
     			
                val nextValue = when(i) {
                    0 -> currentValue + nl[level]
                    1 -> currentValue - nl[level]
                    2 -> currentValue * nl[level]
                    3 -> currentValue / nl[level]
                   	else -> currentValue
                }
                
                dfs(level + 1, nextValue)	// μž¬κ·€
                
                ol[i]++	// μ—°μ‚°μž λ°±νŠΈλž˜ν‚Ή
            }
        }
    }
	
    dfs(1, nl[0])	// DFS 탐색 μ‹œμž‘
    println("${max}\n${min}")	// κ²°κ³Ό 좜λ ₯
}

 

μž¬κ·€νƒμƒ‰μ˜ 경우, λ°±νŠΈλž˜ν‚Ήκ³Ό 짝을 이룬닀.

728x90
λ°˜μ‘ν˜•