Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
99866 | 梁晨熙 | 拆分自然数 | C++ | 通过 | 100 | 432 MS | 260 KB | 464 | 2023-08-24 09:37:58 |
#include<bits/stdc++.h> using namespace std; int n; int ans; int a[1000001]; void dfs(int step,int sum,int minn){ if(sum==n){ cout<<n<<"="; for(int i=1;i<step-1;i++){ cout<<a[i]<<"+"; } cout<<a[step-1]; cout<<endl; ans++; return; } if(sum>=n){ return; } for(int i=minn;i<n;i++){ a[step]=i; dfs(step+1,sum+i,max(minn,i)); a[step]=0; } } int main(){ cin>>n; dfs(1,0,1); cout<<ans<<endl; return 0; }