N과M(10)
> 특이 사항
- N개의 자연수 중에서 M개를 고른 수열.
 
- 고른 수열은 비내림차순이어야 한다.
길이가 K인 수열 A가 A1 ≤ A2 ≤ ... ≤ AK-1 ≤ AK를 만족하면, 비내림차순이라고 한다. 
> 문제 풀이
- 이 문제도 전에 풀었던 것과 같이 비교하는 숫자를 재귀함수에 넣어 비교 하도록 한다.
 
> 프로그램 코드(java)
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.Set;
import java.util.TreeSet;
public class BOJ15664_N과M10 {
	static int N, M;
	static int[] visited = new int[10001];
	static ArrayList<Integer> a;
	static int[] input;
	public static void main(String[] args) throws IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		String[] temp = br.readLine().split(" ");
		N = Integer.parseInt(temp[0]); 
		M = Integer.parseInt(temp[1]);
		input = new int[N];
		temp = br.readLine().split(" ");
		Set<Integer> s = new TreeSet<Integer>();
		for (int i = 0; i < N; i++) {
			int t = Integer.parseInt(temp[i]);
			s.add(t); 
			visited[t]++; 
		}
		a = new ArrayList<Integer>(s); 
		dfs(0, bw, "", a.get(0));
		bw.flush();
		bw.close();
		br.close();
	}
	static void dfs(int depth, BufferedWriter bw, String str, int com) {
		if (depth == M) {
			try {
				bw.write(str + "\n");
			} catch (IOException e) {
				e.printStackTrace();
			}
			return;
		}
		for (int i = 0; i < a.size(); i++) {
			if (visited[a.get(i)] > 0 && com <= a.get(i)) {
				visited[a.get(i)]--;
				dfs(depth + 1, bw, str + a.get(i) + " ", a.get(i));
				visited[a.get(i)]++;
			}
		}
	}
}
