M==20 N==5 算法

题目:给一个整形M,(假设是20),再给出一个N(是把M分成不相等的比M小的数相加的个数),打印出有几种写法例如:

1+2+3+4+10=20;

 

 

 

解:

 

int main()

{

    int M,N;

    cin>>M>>N;

    int *l=(int *)malloc(N*sizeof(int));

    pn(M,N,l,0);

    return 1;

 

}

//p是数组中位置,如果到最后一位的后一位,打印数组

 

 

void pn(int M,int N,int *l,int p)
{
 if(p==N)
 {
  int sum=0;
  for(int i=0;i<N;i++)
  sum+=l[i];
  if(sum==M){
  for(int i=0;i<N;i++)
  cout<<l[i]<<"   ";cout<<endl;
  }
  return;
 }
 else{
  
 if(p)
 {
  if(l[p-1]>=M) return;
  for(int i=l[p-1]+1;i<=M;i++)
  {
   int sum=0;
   l[p]=i;
   for(int j=0;j<=p;j++)
   {
    sum+=l[j];
   }
   if(sum>M)
   {return;}
   else
   {pn(M,N,l,p+1);} 
  }
 
 }
 else{ 
  for(int i=1;i<=M;i++)
  {
   l[p]=i;
   pn(M,N,l,p+1);
  }
 
 
 }
 
 
 }
 
 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值