提交时间:2023-11-18 11:18:17

运行 ID: 111171

#include<bits/stdc++.h> #include<set> using namespace std; set<string> st; int n,a[1010]; bool b[1010]; void f(int x,int u,int l) { if(x==n){ if(l<2) return; string s=""; for(int i=0;i<n;i++) if(b[i]) { s+=(a[i]+'0'); s+=' '; } s=s.substr(0,s.size()-1); st.insert(s); return; } if(a[x]>=u) { b[x]=1; f(x+1,a[x],l+1); } b[x]=0; f(x+1,u,l); } int main() { cin>>n; for(int i=0;i<n;i++) cin>>a[i]; f(0,0,0); int ti=0; for(auto t: st) { ti++; cout<<t<<endl; } return 0; }