提交时间:2023-11-04 09:32:18
运行 ID: 108723
#include<bits/stdc++.h> using namespace std; int n; int sum; vector<int> path; void dfs(int now) { if(now==n) { if(path.size()==1) { return ; } cout<<n; cout<<"="; for(int i=0;i<path.size()-1;i++) { cout<<path[i]; cout<<"+"; } cout<<path[path.size()-1]; cout<<endl; sum++; return ; } for(int i=path[path.size()-1];i<=n-now;i++) { path.push_back(i); dfs(now+i); path.pop_back(); } return ; } int main() { // freopen("split.in","r",stdin); // freopen("split.out","w",stdout); // ios::sync_with_stdio(0); // cin.tie(); // cout.tie(); cin>>n; dfs(0); cout<<"total="; cout<<sum; // fclose(stdin); // fclose(stdout); return 0; }