必威体育Betway必威体育官网
当前位置:首页 > IT技术

分苹果算法

时间:2019-06-01 13:40:00来源:IT技术作者:seo实验室小编阅读:69次「手机版」
 

分苹果

题目内容

把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?M, N为自然数。说明:如有7个苹果,2个盘子,则(5, 1, 1)和(1, 5, 1)和(1, 1, 5)都是同一种分法。

输入描述

第一行一个整数表示数据的组数(多组数据),对于每组数据第一行是苹果个数M (1 ≤ m ≤ 100) ,第二行是盘子个数N(1 ≤ n ≤ 100)。

输出描述

每组数据输出一行,放苹果的方法个数。

输入样例

1 
3 
2

输出样例

2

/*
思路1: 
122 212 221是同种方法,则取代表 221
123 .321 是同种方法,则取代表 321
能当“代表”的组合的特点是,前面的不小于后面的.
这是一个限制条件.
想来想去用递归最好.
比如10个放入3个篮子,变成:
第一个放10,再把0个放入剩余2个篮子
第一个放9,再把1个放入剩余2个篮子
第一个放8,再把2个放入剩余2个篮子
第一个放7,再把3个放入剩余2个篮子
.
总之,M个苹果,N个篮子,
第一个放a个,a的范围是从M减小到0,
而再将(M-a)个苹果放入N-1个篮子.
但是放的时候要一定满足“前面的不小于后面的”.

思路2:
f(m, n)表示将m个苹果放入n个盘子 
f(10,3) = f(10, 2) + f(7, 3) 
10个苹果放入3个盘子 = 10个苹果放入2个盘子(有空盘子,有一个盘子不放)
+ 7个苹果放入3个盘子(没有空盘子,每一个盘子里面先各放一个苹果,就只剩下7个苹果) 
然后递归 ,下面算法按思路2解 
*/ 

#include<stdio.h>  
int fun(int m,int n){   
    if(m==0||n==1)    
        return 1;     
    if(n>m)  
        return fun(m,m);  //如果前面的小于后面的,则一定会有空盘子,则等于m个苹果放入m个盘子 
    else  
        return fun(m,n-1)+fun(m-n,n);  //有空盘子的情况 + 没有空盘子的情况 
}  
int main(){  
    int t,m,n;  
    scanf("%d",&t);  
    while(t--){     
        scanf("%d%d",&m,&n);  
        printf("%d\n",fun(m,n));  
    }  
    return 0;  
}  

相关阅读

苹果也要出智能戒指了,支持多种手势来看看长啥样!

A5创业网(公众号:iadmin5)苹果可能正在研发下一款可穿戴设备&mdash;&mdash;苹果智能戒指。10月15日,苹果向美国专利商标局提交一份文

苹果削减芯片订单 导致供应商市值缩减过半

A5创业网(公众号:iadmin5)6月1日报道,海外媒体称,德国戴乐格半导体公司的市值继续大幅度缩水,该公司的市值已经缩水近一半左右。德国戴

怎么向ipad拷电影 苹果iPad拷电影技巧

如果你是一个影音发烧友,新电脑到手的第一件事就是安装一个好用的播放器。现在有了iPad,完全可以免去这一步:iPad内置的播放器可以播

【人人早报】573期:2016年苹果春季新品发布会

导读北京时间3月22日凌晨,苹果召开了2016年春季发布会。苹果发布了iPhone SE,采用A9处理器,4种颜色可选,售价399美元起。iPhone SE采

苹果发布跨平台、提供包月单机游戏打包服务的 Apple A

A5创业网(公众号:iadmin5)3月26日消息,苹果在今天凌晨的发布会上发布了游戏平台Apple Arcade。Apple Arcade 将主打原创性、高品质以

分享到:

栏目导航

推荐阅读

热门阅读