Chri_K

自然数的拆分(dfs)
#include<iostream>
using namespace std;
int a[100],n,m;
void dfs(int dep,int pre,int sum) 
{
    if(sum==n) 
    {        
        for(int i=1; i<=dep-1; i++) 
        {
            cout<<a[i];
            if(i!=dep-1)
            {
                cout<<"+";    
            }
        }
        cout<<endl;
        return;        
    }
    for(int i=pre; i<=n-1; i++) 
    {        
        if(sum+i<=n) 
        {        
            a[dep]=i;
            dfs(dep+1,i,sum+i);
        }
    }
}
int main() 
{
    cin>>n;        
    dfs(1,1,0);
    return 0;
}

 

posted on 2020-10-22 16:30  Chri_K  阅读(126)  评论(0编辑  收藏  举报