小球进盒子C语言,N个小球放进M个盒子算法-Go语言中文社区

N个小球放入M个盒子共有多少种方法,并输出的算法设计:

算法思路1 :暴力填充盒子

每个小球都可能放入M个盒子的任意一个,所以直接根据小球个数做递归即可,然后将存储放入hash中排重

//TODO

算法思路2 :递归填充盒子

即,每层递归仅考虑一个盒子放几个球,剩下的球交给下一个递归。

比如第一个盒子里放N个球,则剩下的都是0个;第一个盒子放n-1个球,问题就变成了1个球与M-1个盒子的问题...直到第一个盒子放0个球,问题变成了N个球与M个盒子的问题。

递归的入口是第1个盒子,那么递归的出口在哪?自然是最后一个盒子。当盒子只剩一个时候便不向下递归,还剩多少小球就全放进盒子里。

f3ceb9a76480a02df6e3b994251b14d6.png

递归伪代码如下:

public void everyBox(int boxes , int balls ,String oneResult ){

if (boxes ==1){                       //递归出口

thisResult = oneResult+balls

return

}

for( i=balls ; i >=0 ; i -- ){

thisResult  = oneResult + (String) i

everyBox(boxes-1 , balls-i , thisResult)  //递归

}

}

算法2优化:

上述递归只有一个出口,就是只剩一个box时候。不过这个程序还有一个可以优化的出口:在balls等于0的时候。假设还剩余X个盒子没有进行递归,而这时候剩余ball是0,便不用递归了,直接输出X个0即可。当盒子数>>小球数时候,可以极大减少递归的层次,提高代码效率。

优化后的java示例代码如下,由于要输出就直接systemout了:

public class NballMbox {

public static void main(String[] args) {

NballMbox nm = new NballMbox();

nm.iterator(4, 2, "");

}

public void iterator(int balls , int boxes , String s){

//ball =0 直接结算

if(balls == 0){

for(int i = 0 ;i< boxes ;i++)

s = s+ 0;

System.out.println(s.toString());

return;

}

for(int i =balls;i >=0;i--){

String s1 = s+i;

if(boxes == 1){

System.out.println(s1.toString());

return;

}

else

this.iterator(balls-i, boxes-1, s1);

}

}

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574255.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

r语言c5.0要求因子输出,R语言中因子的创建与使用

原标题&#xff1a;R语言中因子的创建与使用因子在R语言中可以用来表示名义型变量或有序变量。名义变量一般表示类别&#xff0c;如性别&#xff0c;种族等等。有序变量是有一定排序顺序的变量&#xff0c;如职称&#xff0c;年级等等。在R语言中&#xff0c;名义变量和有序变量…

WinForm中使用AnyCAD三维控件 の 初始化

在WinForm中可以方便的集成AnyCAD.Net三维控件&#xff0c;只需要以下几部即可完成。 一、添加DLL程序集 AnyCAD.Foundation.Net.dll AnyCAD.Presentation.Net.dll AnyCAD.Exchange.Net.dll 二、初始化控件 1.首先创建一个窗体 2.在窗体上放置一个Panel用来放置三维控件 3.初始…

android l usb调试,你居然还不会手机usb调试?5个方法,让你轻松学会设置!

原标题&#xff1a;你居然还不会手机usb调试&#xff1f;5个方法&#xff0c;让你轻松学会设置&#xff01;最近有位朋友将手机连接电脑的时候&#xff0c;遇到了提示打开手机的USB调试模式&#xff0c;却不知道怎么操作。其实&#xff0c;不同手机的usb调试打开的方式都会有所…

鸿蒙os芯片,没有了芯片,华为能靠鸿蒙OS系统打出差异化吗?

原标题&#xff1a;没有了芯片&#xff0c;华为能靠鸿蒙OS系统打出差异化吗&#xff1f;华为今天要和大家说的手机产品是华为&#xff0c;在目前的市场中&#xff0c;华为手机的影响力是非常大的&#xff0c;并且获得了十分不错的销量&#xff0c;甚至在最近一段时间销量超过三…

html5 canvas 不兼容safari浏览器_HTML5简介

HTML5 是继 HTML4.01 和 XHTML1.0 之后的超文本标记语言的最新版本。它是由一群自由思想者组成的团队设计出来&#xff0c;并最终实现多媒体支持、交互性、更加智能的表单&#xff0c;以及更好的语义化标记。HTML5 并不仅仅是 HTML 规范的最新版本&#xff0c;而是一系列用来制…

html5置顶标签css样式,html5 header标签 html header css布局教程 /header

在HTML5版本之前习惯使用div标签布局网页&#xff0c;在HTML5在DIV标签基础上新增header标签元素。也叫“”头部标签。以前我们在div css布局中常常把网页大致分为头部、内容、底部。对于大结构我们常常使用div里加id进行布局。而头部常常使用正应为大家公认html布局中对“head…

第八届育才杯机器人比赛_赛场、名单公布!南海区第八届“献血者杯”羽毛球公开赛“羽”你相约本周六...

主办单位&#xff1a;南海区献血办、南海血站协办单位&#xff1a;南海区羽毛球协会为进一步扩大无偿献血宣传&#xff0c;感恩南海区献血者&#xff0c;活跃无偿献血者的文体生活&#xff0c;打造一个南海区无偿献血者交流的平台&#xff0c;共同营造“运动、健康、献血、快乐…

2021届安徽高考成绩查询,安徽2021年高考成绩什么时候公布

据安徽省教育招生考试院透露&#xff0c;安徽预计将于6月23日公布各批次录取分数线、考生成绩。2021年安徽高考成绩查询入口2021年高考录取方法1、普通高校的招生录取工作在教育部和省高校招生委员会的领导下&#xff0c;由省考试院组织实施。2、省高校招生委员会根据当年高校在…

BroadcastReceiver 广播机制详解

BroadcastReceiver也就是“广播接收者”的意思&#xff0c;顾名思义&#xff0c;它就是用来接收来自系统和应用中的广播。 在Android系统中&#xff0c;广播体现在方方面面&#xff0c;例如当开机完成后系统会产生一条广播&#xff0c;接收到这条广播就能实现开机启动服务的功能…

会话管理 轻量php框架_SpringSecurity+JWT权限管理训练营-1基于RBAC模型的权限管理系统...

1.什么是权限管理系统&#xff1f;权限管理是一个几乎所有后台系统的都会涉及的一个重要组成部分&#xff0c;可以说是后台项目的基本功&#xff0c;主要目的是对整个后台管理系统进行权限的控制&#xff0c;而针对的对象是员工&#xff0c;避免因权限控制缺失或操作不当引发的…

2021宣城职业技术学院对口高考成绩查询,2021年宣城职业技术学院高考录取通知书查询 通知书什么时候可以收到...

高考志愿填报后最重要的一件事情就是高考录取通知书的查收了&#xff0c;因为录取通知书才是证明你被录取的有效方式。那么很多考生及家长最关心怎么查询宣城职业技术学院录取通知书&#xff1f;宣城职业技术学院录取通知书寄到哪里了&#xff1f;本文大风车网小编为你整理了关…

iOS 谓词的使用

OC中的谓词操作是针对于数组类型的&#xff0c;他就好比数据库中的查询操作&#xff0c;数据源就是数组&#xff0c;这样的好处是我们不需要编写很多代码就可以去操作数组&#xff0c;同时也起到过滤的作用&#xff0c;我们可以编写简单的谓词语句&#xff0c;就可以从数组中过…

multisim秒信号发生器_失联50年的卫星突然出现,莫名向地球发送信号,究竟谁在操控?...

大不列颠无线电学会(RSGB)接到英国康沃尔郡的业余无线电天文爱好者菲尔威廉姆斯(无线电呼叫代号&#xff1a;G3YPQ)的报告&#xff0c;他在2012年12月18日的一次惯例搜索轨道卫星信号的任务中突然搜到了一个237MHZ&#xff0c;每隔4秒重复一次的信号&#xff0c;很明显这是一个…

html 百度地图显示轨迹,百度地图,地图轨迹

百度地图&#xff0c;记录行动轨迹&#xff1a;效果图&#xff1a;上代码&#xff1a;body,html,#allmap {width: 100%;height: 100%;overflow: hidden;margin: 0;font-family: "微软雅黑";}单个标注点沿直线的轨迹运动// 百度地图API功能var map new BMap.Map(&quo…

win10微软图标点击无反应_win10开始菜单,不出来,任务栏右击无反应

使用【win】【R】快捷键打开系统的【运行】&#xff1b;输入【powershell】&#xff0c;按下【确定】运行&#xff0c;然后复制一行命令&#xff0c;点击回车键运行等待命令运行完成之后就可以了。以下是详细介绍&#xff1a;1、在键盘上按下【win】【R】键&#xff0c;使用快捷…

计算机仿真在哪学,计算机仿真软件有哪些

虚拟机&#xff0c;如VMWARE&#xff0c;Virtual PC虚拟机软件可以在一台电脑上模拟出来若干台PC&#xff0c;每台PC可以运行单独的操作系统而互不干扰&#xff0c;可以实现一台电脑“同时”运行几个操作系统&#xff0c;还可以将这几个操作系统连成一个网络。使用虚拟机的好处…

WebApp的前端所遇问题

2015年10月1日至10月25日&#xff0c;两个本科生和一位研究生以及一位老师组成四人团队&#xff0c;开发某教育前端项目 所遇问题总结以及分享&#xff1a; 一、主要应用软件&#xff1a;sublime_text HBuilder 初学者可以在JQuery mobile的Demo中寻找代码&#xff08;可以看图…

框架的特性_Go 语言 Web 框架 Echo 系列:基础篇—通过一个例子串联各特性

通过前面的介绍&#xff0c;相信对 echo 有了一个初步的认识。本文我们通过一个简单的登录页面来串联 echo 的相关特性。因为该文主要关注各个特性&#xff0c;所以在目录结构和代码组织方面很随意。本节最终效果1)登录页面2)登录失败3)登录成功main 函数骨架使用 echo 框架&am…

计算机网络日志查询,系统资源管理_百络网警内网管理软件_电脑配置统计,系统日志,日志查询...

管理作用管理者可以使用百络网警内网gua灵活查询的分类统计网内计算机的硬件和软件信息&#xff0c;为IT资产管理提供方便和决策支持。也可以让IT管理者从多个角度来了解网络内每台计算机的全面的日志信息&#xff0c;为故障排除和网络管理提供有力支持。功能描述1、资产管理选…

南京江南贡院值得去吗_这12个地方是一种瘾,值得一去再去,有你想要去的吗?...

有人说&#xff0c;旅行就是从一个自己呆腻了的地方&#xff0c;到别人呆腻了的地方去。但大家有没有发现&#xff0c;去过许多地方&#xff0c;看过那么多风景&#xff0c;总有一些地方&#xff0c;第一次初识&#xff0c;第二次上瘾&#xff0c;第三第四次还去不腻&#xff1…