任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和。

任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和。
n=714种拆分方法:
7=1+1+1+1+1+1+1
7=1+1+1+1+1+2
7=1+1+1+1+3
7=1+1+1+2+2
7=1+1+1+4
7=1+1+2+3
7=1+1+5
7=1+2+2+2
7=1+2+4
7=1+3+3
7=1+6
7=2+2+3
7=2+5
7=3+4
total=14
 
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cmath>
using namespace std;
int a[100000]={1};int n,tot;
void dfs(int,int);
void print(int);
int main()
{
    cin>>n;
    dfs(n,1);
    cout<<"total="<<tot;
    return 0;
}
void dfs(int p,int q)
{
    int i;
    for(i=a[q-1];i<=p;i++)
    {
        if(i<n)
        {
            a[q]=i;
            p-=i;
            if(p==0)print(q);
            else dfs(p,q+1);
            p+=i;
        }
    }
}
void print(int j)
{
    tot++;
    cout<<n<<"=";
    for(int i=1;i<=j;i++)
    {
        if(i!=j)
        cout<<a[i]<<"+";
        else cout<<a[i];
    }
    cout<<endl;
}

 

posted @ 2017-03-23 19:35  zzzzx  阅读(5444)  评论(0编辑  收藏  举报