编程:现有1克,2克,3克,…100克砝码充分多枚,组合成100克共有多少种方式?

2024-05-24 06:08

本文主要是介绍编程:现有1克,2克,3克,…100克砝码充分多枚,组合成100克共有多少种方式?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JAVA实现拉马努金的整数拆分全排列

致敬神一般的拉马努金

点此跳转:非递归方式

由于电脑垃圾,递归算不出来结果,结果在非递归方式的文章
编程:现有1克,2克,3克,…100克砝码充分多枚,组合成100克共有多少种方式?
偶然看见有这么一个面试题,新人小白,网上搜了一下,貌似并没有相关的答案和代码,所以特意自己记录一下,并发表一下,新人小白,错了勿喷。

首先这个题,乍一看,就想到了递归,作为递归,要注意几个点,第一:找到跳出点,第二,找到规律。
那么我们开始吧,注意是充分多枚,从0开始,0克组合方式1种,1克组合方式1种,2克组合方式2种,那么继续推,3克的砝码组合方式是3种,4克的方法组合方式是5种,到了这里,肯定有小伙伴觉得这简单,这不就是斐波那契数列吗?不急,5克的砝码组合方式是7种,到了这里就发现不对劲了,斐波那契数列是112358,可是这里是112357,很明显不是了,继续:1,1,2,3,5,7,11,15,22,30.好了,这里可以明显的发现这不是斐波那契数列,是拉马努金的整数拆分全排列。
*神一般的拉马努金~~~~~*
具体公式大家可以百度,这里我贴一下公式图:
在这里插入图片描述
在这里插入图片描述
好了既然知道了规律,也有了跳出条件,0,1都只有固定一种。
那么我们接下来就用JAVA,用递归的方式来实现一遍吧。
过程着实复杂,看不懂的看注释吧。。。。。。

/*** * @author An* 拉马努金的整数拆分**/
public class Test03 {public static void main(String[] args) {int result=f1(100);System.out.println(result);}private static int f1(int i) {int result = 0;//表示最终结果int count = 1;//表示循环的次数,用来控制下标int n =1;//表示当前下标下,应该传入的数boolean flag = true;//控制加减,true=+,false= -if(i==0||i==1) {return 1;//0和1的拆分次数固定是1种,也是递归的出口}else {while(i-n>=0){//i-应该减掉的n<0跳出if(count==1) {					result +=f1(i-n);count++;//下标置为第二次n= count;//第二次应该减掉的数
//count=1的时候,表示循环刚开始,应该添加i-n(默认初始值1)}else if(count==2) {result +=f1(i-n);count++;//下标继续自增n =count*2-1;//第三次下标预设flag=!flag;//此时修改标志位,false=减少
//count=2,循环开始第二次,第一个已添加,第二是i-2,}else {if(count%2!=0) {//求模,可以知道是单数or双数,单数无需修改标志位result=(flag==true ? result+f1(i-n) : result-f1(i-n));//三目运算,根据标志位,决定是+是-count++;//标志位继续增加n +=count/2;//后面的单数规律。}else {//求模,可以知道是单数or双数,单数无需修改标志位result=(flag==true ? result+f1(i-n) : result-f1(i-n));count++;//标志位继续增加n +=count;//后面的双数规律flag = !flag;//双数后要修改标志位}}}}return result;}
}

等会继续上传非递归的方式。。。。。。第一次发帖记录一下,小白一枚,若有错误,望大神见谅。有问题希望大神指教~~~~~
非递归方式

这篇关于编程:现有1克,2克,3克,…100克砝码充分多枚,组合成100克共有多少种方式?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/997587

相关文章

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re