https://www.acmicpc.net/problem/15649
1. 아이디어
1부터 N까지의 순열을 구하면 된다.
2. 문제풀이
재귀 함수와 반복문의 활용으로 간단하게 구현할 수 있다.
3. 코드
import java.io.*;
import java.util.*;
public class Main {
private static final StringBuilder sb = new StringBuilder();
private static int[] arr;
private static boolean[] visited;
private static int[] sel;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st = new StringTokenizer(br.readLine());
int N = Integer.parseInt(st.nextToken());
int M = Integer.parseInt(st.nextToken());
arr = new int[N];
visited = new boolean[N];
sel = new int[M];
permutation(0);
bw.write(sb.toString());
bw.flush();
}
// 순열
private static void permutation(int selIdx) {
if (selIdx == sel.length) {
for (int n : sel) {
sb.append(n).append(" ");
}
sb.append("\n");
return;
}
for (int i = 0; i < arr.length; i++) {
if (visited[i]) continue;
sel[selIdx] = i + 1;
visited[i] = true;
permutation(selIdx + 1);
visited[i] = false;
}
}
}
4. 후기
'코딩테스트 준비 > 백준' 카테고리의 다른 글
[백준] 15651번 - N과 M (3) [Java] (0) | 2025.01.11 |
---|---|
[백준] 15650번 - N과 M (2) [Java] (0) | 2025.01.11 |
[백준] 18809번 - Gaaaaaaaaaarden [Java] (0) | 2025.01.11 |
[백준] 1941번 - 소문난 칠공주 [Java] (0) | 2025.01.11 |
[백준] 16987번 - 계란으로 계란치기 [Java] (0) | 2025.01.11 |