🔍 알고리즘/SWEA
[Java] SWEA 4008.숫자만들기 (모의SW테스트)
탄치
2022. 7. 12. 23:47
https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AWIeRZV6kBUDFAVH
SW Expert Academy
SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!
swexpertacademy.com
숫자카드는 고정되어 있고 그 사이에 들어갈 연산자만 정해주면 됩니다.
연산의 순서는 우리가 기존에 알던 수학과 달리 무조건 좌측부터 진행됩니다.
조금 더 효율적인 계산을 위해 연산자를 모두 정하고 나서 계산하지 않고, 재귀함수 내부에서 값을 가진 채 진행하면서 구현했습니다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class q4008_SWEA_숫자만들기 {
static StringTokenizer st;
static StringBuilder sb = new StringBuilder();
static int N, max, min;
static int[] num;
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int T = Integer.parseInt(br.readLine());
int answer;
for(int tc = 1; tc <= T ; tc++){
max = Integer.MIN_VALUE;
min = Integer.MAX_VALUE;
N = Integer.parseInt(br.readLine());
num = new int[N];
st = new StringTokenizer(br.readLine());
int[] op = {Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken())};
st = new StringTokenizer(br.readLine());
for(int n = 0; n < N; n++) {
num[n] = Integer.parseInt(st.nextToken());
}
dfs(num[0], 1, op[0], op[1], op[2], op[3]);
answer = max-min;
sb.append("#").append(tc).append(" ").append(answer).append("\n");
}
System.out.println(sb);
}
static void dfs(int result, int count, int plus, int minus, int multiple, int divide) {
if(count == N) {
if(result < min) {
min = result;
}
if(result > max) {
max = result;
}
}
if(plus > 0) {
dfs(result + num[count], count+1, plus-1, minus, multiple, divide);
}
if(minus > 0) {
dfs(result - num[count], count+1, plus, minus-1, multiple, divide);
}
if(multiple > 0) {
dfs(result * num[count], count+1, plus, minus, multiple-1, divide);
}
if(divide > 0) {
dfs(result / num[count], count+1, plus, minus, multiple, divide-1);
}
}
}
728x90