백준 1469번 숌 사이 수열 Java

: ) YOUNG·2024년 2월 2일
1

알고리즘

목록 보기
309/441
post-thumbnail

백준 1469번
https://www.acmicpc.net/problem/1469

문제



생각하기


  • 백트래킹 문제이다. 경우의 수를 만들어야 하는데, 좀 까다롭다...

동작


comb[]에 들어가야 하는 수가 i라면 S에서 두 번 등장하는 i사이에는 수가 i개 등장해야 한다. 는 규칙을 맞추기위해 comb[depth] = comb[depth + arr[i] + 1] = arr[i] 라는 규칙으로 맞춰준다.

결국 arr[i]의 값을 인덱스로도 사용하는 규칙을 찾으면 된다.



결과


코드



import java.io.*;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {

    // input
    private static BufferedReader br;

    // variables
    private static int N;
    private static boolean[] isVisited;
    private static int[] arr, comb;
    private static StringBuilder sb;

    public static void main(String[] args) throws IOException {
        br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

        input();

        bw.write(solve());
        bw.close();
    } // End of main()

    private static String solve() {
        sb = new StringBuilder();

        DFS(0);
        if (sb.length() == 0) {
            sb.append(-1);
        }

        return sb.toString();
    } // End of solve()

    private static void DFS(int depth) {
        if (depth == 2 * N) {
            for (int i = 0; i < N * 2; i++) {
                sb.append(comb[i]).append(' ');
            }
            return;
        }

        if (sb.length() != 0) return;

        if (comb[depth] != -1) {
            DFS(depth + 1);
            return;
        }

        for (int i = 0; i < N; i++) {
            if (isVisited[i]) continue;
            if (depth + arr[i] + 1 < N * 2 && comb[depth] == -1 && comb[depth + arr[i] + 1] == -1) {
                isVisited[i] = true;
                comb[depth] = comb[depth + arr[i] + 1] = arr[i];
                DFS(depth + 1);
                comb[depth] = comb[depth + arr[i] + 1] = -1;
                isVisited[i] = false;
            }
        }
    } // End of DFS()

    private static void input() throws IOException {
        N = Integer.parseInt(br.readLine());
        arr = new int[N];
        comb = new int[N * 2];
        Arrays.fill(comb, -1);
        isVisited = new boolean[N * 2];

        StringTokenizer st = new StringTokenizer(br.readLine());
        for (int i = 0; i < N; i++) {
            arr[i] = Integer.parseInt(st.nextToken());
        }
        Arrays.sort(arr);
    } // End of input()
} // End of Main class

0개의 댓글