문제
링크
풀이
#include <iostream>
#include <set>
#include <string>
using namespace std;
set<string> st;
void backtrack(string cur, int n) {
if (n == 0) {
st.insert(cur);
return;
}
if (n >= 1) backtrack(cur + "+1", n-1);
if (n >= 2) backtrack(cur + "+2", n-2);
if (n >= 3) backtrack(cur + "+3", n-3);
}
void solve(void) {
int n, k; cin >> n >> k;
if (n >= 1) backtrack("1", n-1);
if (n >= 2) backtrack("2", n-2);
if (n >= 3) backtrack("3", n-3);
while (--k && !st.empty()) st.erase(st.begin());
cout << (st.empty() ? "-1" : *st.begin());
}
int main(void) {
ios::sync_with_stdio(false);
cin.tie(nullptr);
solve();
return 0;
}