문제 ⭐️
- 소요 시간 ⏰: 30min

- 중복을 허용
- 비내림차순(중복을 허용한 오름차순)
코드 💻
#include <iostream>
#include <algorithm>
#define MAX 9
using namespace std;
int n, m;
int arr[MAX];
int input[MAX];
int isused[MAX];
void bfs(int cnt, int num){
if(cnt == m){
for(int i=0; i<m; i++){
cout << arr[i] << ' ';
}
cout << '\n';
return;
}
for(int i=num; i<n; i++){
arr[cnt] = input[i];
isused[i] = true;
bfs(cnt+1, i);
isused[i] = false;
}
}
int main() {
cin >> n >> m;
for(int i=0; i<n; i++){
cin >> input[i];
}
sort(input, input+n);
bfs(0, 0);
return 0;
}
풀이 ✏️
- 중복을 허용하기 때문에 if(!isused[i]) 는 뺌
- num 값으로 i를 넘겨줘서 앞의 자리수부터 시작하도록 함