鱼C论坛

 找回密码
 立即注册
查看: 2937|回复: 2

球与盒子的分类问题

[复制链接]
发表于 2016-4-17 20:22:11 | 显示全部楼层 |阅读模式
10鱼币
定义一个函数f(n,r),希望实现这样的功能:列出所有可能的n个自然数之和为r的组合。
比如说,输入f(3,4),希望输出的是
4,0,0
3,1,0
2,2,0
2,1,1

望大神们给些思路!

最佳答案

查看完整内容

相当于r个球分别放到n个框, 每次放一个球,列出所有可能的情况, 去重, 然后再放一个球,重复 直到所有的球放完
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-4-17 20:22:12 | 显示全部楼层
  1. def f(box,ball):
  2.     lis0=[0]*box
  3.     lis1=[lis0]
  4.     lis2=[]
  5.     for i in range(ball):
  6.        for each in lis1:
  7.            for j in range(box):
  8.                lis3=each[:]
  9.                lis3[j]+=1
  10.                lis4=lis3[:]
  11.                lis4.sort()
  12.                if lis4 not in lis2:
  13.                    lis2.append(lis4)
  14.                    lis5=lis2[:]
  15.        lis1=lis2[:]
  16.        lis2=[]   
  17.     for each in lis5:
  18.         print(each)

  19. f(3,4)
复制代码

相当于r个球分别放到n个框,
每次放一个球,列出所有可能的情况,
去重,
然后再放一个球,重复
直到所有的球放完
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-4-17 21:34:52 | 显示全部楼层
这样应该就可以了:
  1. from itertools import combinations
  2. def f(n, r):
  3.     for i in combinations(n*[j for j in range(r+1)],n):
  4.         if sum(i) == r:
  5.             yield i

  6. if __name__ == '__main__':
  7.     print(set(list(f(3,4))))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-20 17:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表