1. 순열 이용
#include<bits/stdc++.h>
using namespace std;
int a[9];
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
for(int i = 0; i < 9; i++){
cin >> a[i];
}
// 순열 사용할 땐 무조건 오름차순 정렬 후 사용할 것!
sort(a, a+9);
do{
for(int i : a)cout << i << " ";
cout << '\\n';
int sum = 0;
for(int i = 0; i < 7; i++) sum += a[i];
if(sum == 100) break;
}while(next_permutation(a, a+9));
for(int i = 0; i < 7; i++)cout << a[i] << '\\n';
return 0;
}
2. 조합 이용
#include<bits/stdc++.h>
using namespace std;
int a[9];
int sum = 0;
vector<int> v;
pair<int, int> fake;
void solve() {
for(int i = 0; i < 9; i++){
for(int j = 0; j < i; j++){
if(sum - a[i] - a[j] == 100){
fake = {i, j};
return;
}
}
}
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
for(int i = 0; i < 9; i++){
cin >> a[i]; sum += a[i];
}
solve();
for(int i = 0; i < 9; i++){
// fake의 요소일 경우 가짜 난쟁이. continue로 거름.
if(fake.first == i || fake.second == i)continue;
v.push_back(a[i]);
}
sort(v.begin(), v.end());
for(int i : v)cout << i << "\\n";
return 0;
}