N과M(5)
> 문제 풀이
- N개의 자연수 중에서 M개를 고른 수열
N과 M 문제는 1~4, 5~8, 9~12마다 문제의 유형이 다르다. 하지만 각 문제번호 -4 의 문제와 비슷한 점을 지니고 있다. N과M(1)의 문제와 다른 점은 숫자가 주어지고 이것을 오름차순으로 보여야 한다는 점에 있다. 처음 생각한 것은 주어진 숫자를 배열에 담고 그 배열을 sorting 하는 것이다.  
- 정렬은 java.util.Arrays 라이브러리에 있는 Arrays.sort를 이용하거나, 직접 구현하는 방법이 있다.
 
> 프로그램 코드(java)
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
public class BOJ15654_N과M5 {
	static int N, M;
	static boolean[] visited;
	static int[] a; 
	static int[] input;
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		String[] temp = br.readLine().split(" ");
		N = Integer.parseInt(temp[0]); 
		M = Integer.parseInt(temp[1]);
		visited = new boolean[N];
		a = new int[N];
		input = new int[N];
		temp = br.readLine().split(" ");
		for (int i = 0; i < N; i++) {
			input[i] = Integer.parseInt(temp[i]);
		}
		Arrays.sort(input);
		dfs(0);
	}
	static void dfs(int depth) {
		if (depth == M) {
			for (int i = 0; i < M; i++) {
				System.out.print(a[i] + " ");
			}
			System.out.println();
			return;
		}
		for (int i = 0; i < input.length; i++) {
			if (!visited[i]) {
				visited[i] = true;
				a[depth] = input[i];
				dfs(depth + 1);
				visited[i] = false;
			}
		}
	}
}