python实现整数分为几个数的和(原创+详解)

python实现整数分为几个数的和

问题重述:

如何实现整数分为几个数的和,可以理解为一个整数的分箱问题

简单叙述解题思路:

比如:4这个整数,最多分为4个箱(1,1,1,1);最少一个箱(4)

所以我们定义一个长度为四的数组,每个数组最大能取到4(所以想到5进制),开始循环遍历(四个元素之和等于4即满足条件)

0001

0002

0003

0004(满足)

0010

0011

0012

0013(满足)

0014

0020

......

4440

4441

4442

4443

4444

 

当然啦这过程中会有重复的分箱,比如

0004

0040

0400

4000

所以在写程序的时候把满足相加等于4的元素,把含有0的全部弹出来,之后再出重就得到答案了。

废话不多说,代码实现如下:

程序中的a的就是我们输入的一个整数值,这里的a取list的长度

#-*-encoding=utf-8-*-
import itertools
from itertools import product

import  numpy as np
def max_values(n,x):
    max_value=0
    iters=np.arange(0,x,1)
    for i in iters:
        max_value= np.power((n-x+2),i)*(n-x+1)+max_value
    return max_value

def min_values(n,x):
  
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路易三十六

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值