[JAVA/백준] 백트래킹: 연산자 끼워넣기

👀 문제

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

👊 도전

풀이 방법 1

1. 설계

  1. 배열을 이용하여 숫자와 연산자의 갯수를 저장한다.
  2. DFS를 이용하여 모든 경우의 수의 합을 구한다.
  3. 이중 최댓값과 최솟값을 리턴한다.

2. 구현 (성공 코드)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import java.util.Scanner;

/**
 * 
 * @author HEESOO
 *
 */
public class Main {
	static int[] number;
	static int[] operator;
	static int min=Integer.MAX_VALUE;
	static int max=Integer.MIN_VALUE;
	
	public static void dfs(int idx, int sum){
		if(idx==number.length){
			if(min>sum) min=sum;
			if(max<sum) max=sum;
			return;
		}
		if(operator[0]>0){
			operator[0]--;
			dfs(idx+1, sum+number[idx]);
			operator[0]++;
		}
		if(operator[1]>0){
			operator[1]--;
			dfs(idx+1, sum-number[idx]);
			operator[1]++;
		}
		if(operator[2]>0){
			operator[2]--;
			dfs(idx+1, sum*number[idx]);
			operator[2]++;
		}
		if(operator[3]>0){
			operator[3]--;
			dfs(idx+1, sum/number[idx]);
			operator[3]++;
		}
	}
	public static void main(String[] args){
		Scanner input=new Scanner(System.in);
		int n=input.nextInt();
		number=new int[n];
		operator=new int[4];
		for(int i=0;i<n;i++){
			number[i]=input.nextInt();
		}
		for(int i=0;i<4;i++){
			operator[i]=input.nextInt();
		}
		
		dfs(1, number[0]);
		System.out.println(max);
		System.out.println(min);
		
	}
}
 

3. 결과

실행결과 🤟 성공 🤟

4. 설명

  1. DFS를 이용한다.
    • 연산자를 사용할 수 있다면 operator–하고 해당 연산자에 대한 결과값을 파라미터로 넘겨 다시 dfs()를 재귀호출한다.
    • 이때 결과값과 함께 다음 사용할 숫자 인덱스 번호도 같이 넘겨준다.
    • 하나의 식이 완성된다면 그 결과값이 max, min 조건에 만족하는지 확인한다.
    • 계산이 끝나 return되어 다시 재귀를 호출한 곳으로 복귀된 다음에는, 해당 연산자를 다음 식에서도 사용할 수 있게 하기 위해 연산자 갯수를 원상복구시킨다.

👏 해결 완료!

참고