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;
}