1.问题描述

 比如9个数中取4个数的组合以及列出各种组合,该如何做?

 我们可以考虑以下一个简单组合:从1,2,3,4,5,6中,如何选取任意四个数的组合。

 固定:1   2  3  ,组合有1234 1235 1236 

 固定1 2 4,组合有:1245 1246

 固定1 2 5,组合有:1256

固定1 3 4,组合有:1345 1346

 固定1 3 5,组合有:1356

 固定1 4 5,组合有:1456

 固定2 3 4,组合有:2345 2346

 固定2 3 5,组合有:2356

 固定2 4 5,组合有:2456

 固定3 4 5,组合有:3456

  共有15种组合

2.简单实现一下组合算法

  首先,我们分析上面列出的10个步骤,对于1),很明显,在固定了1 2 3这三个数之后,第四个数就是4、5、6三个数进行了循环(还记得循环吗,计算机最拿手的就是做循环)。其次,我们再分析1)2)3)这三个步骤中固定的数字,前两个没有变,都是1 2,只是第三个数在进行循环(又是循环)。

  通过分析,我们可以找到这样的规律:

    1    先固定3个数,让第四个数进行循环

    2    让第三个数循环,重复第一步

    3    让第二个数循环,重复第一步

    4    让第一个数循环,重复第一步

  1. def combNumberLoop4(m, b):
  2. totalNumber = 0
  3. for i in range(1, m+2-4):
  4. b[0] = i
  5. for j in range(i+1, m+2-3):
  6. b[1] = j
  7. for k in range(j+1, m+2-2):
  8. b[2] = k
  9. for l in range(k+1, m+2-1):
  10. b[3] = l
  11. print b
  12. totalNumber += 1
  13. return totalNumber
  14.  
  15. group=[99,99,99,99]
  16. print "\nUsing Loop: %d\n" % combNumberLoop4(6, group)

  程序的输出结果,正如之前分析的那样。

3.如何递归解决组合问题

  我们再回到C(6,4)问题,除了上面列出的十个步骤,我们换个思路:

    如果在6个数中选定一个数,那么确定剩下的3个数是不是变为了“从5个数中选3个数的组合问题”了呢?以此类推,这似乎变成了一个“递归”问题了,确实,我们可以用递归的思路来解决这个问题。

    对于C(m, n)列出所有组合的问题,可以按照一下的步骤来进行编程,这次我们按从后往前的顺序来列出所有组合:

      1   选定一个元素i,在范围[m, n]内进行循环

      2   将i 作为所求组合的最后一个元素

      3   如果n-1>0,进行递归调用,求C(m-1, n-1);否则,输出结果

      4   重复①

    注意,设计递归函数一定要有终止条件,否则会造成“死循环”。

实现的代码如下:

  1. def combNumber(m, n, b):
  2. global totalNumberR
  3. for i in range(m, n-1, -1):
  4. b[n-1] = i
  5. if n-1>0:
  6. combNumber(i-1,n-1,b)
  7. else:
  8. print b
  9. totalNumberR += 1
  10. return totalNumberR
  11.  
  12. group=[99,99,99,99,99]
  13. totalNumberR = 0
  14. print "\nUsing Recursive: %d\n" % combNumber(7,5,group) 

  递归的使用,让程序写起来非常的简洁,但是,在写程序的时候,我有两个地方(其实程序也就难在这两个地方),折腾了好几天才弄清楚:

     首先是for循环的循环范围如何确定;

     其次是递归调用时使用的参数设计;

3.python提供的内置组合函数

  1. def combinations_with_replacement(iterable, r):
  2. # combinations_with_replacement('ABC', 2) --> AA AB AC BB BC CC
  3. pool = tuple(iterable)
  4. n = len(pool)
  5. if not n and r:
  6. return
  7. indices = [0] * r
  8. yield tuple(pool[i] for i in indices)
  9. while True:
  10. for i in reversed(range(r)):
  11. if indices[i] != n - 1:
  12. break
  13. else:
  14. return
  15. indices[i:] = [indices[i] + 1] * (r - i)
  16. yield tuple(pool[i] for i in indices)

4.更多组合算法

  请点击我:https://docs.python.org/3/library/itertools.html?highlight=combinations#itertools.combinations

  

python解决组合问题的更多相关文章

  1. C# 解决组合优化问题

    Google Optimization Tools介绍 Google Optimization Tools(OR-Tools)是一款专门快速而便携地解决组合优化问题的套件.它包含了: 约束编程求解器. ...

  2. python笔记-用python解决小学生数学题【转载】

    本篇转自博客:上海-悠悠 原文地址:http://www.cnblogs.com/yoyoketang/tag/python/ 前几天有人在群里给小编出了个数学题: 假设你有无限数量的邮票,面值分别为 ...

  3. python的组合数据类型及其内置方法说明

    python中,数据结构是通过某种方式(例如对元素进行编号),组织在一起数据结构的集合. python常用的组合数据类型有:序列类型,集合类型和映射类型 在序列类型中,又可以分为列表和元组,字符串也属 ...

  4. 《用Python解决数据结构与算法问题》在线阅读

    源于经典 数据结构作为计算机从业人员的必备基础,Java, c 之类的语言有很多这方面的书籍,Python 相对较少, 其中比较著名的一本 problem-solving-with-algorithm ...

  5. 有关科学计算方面的python解决

    在科学计算方面,一般觉得matlab是一个超强的东西.此外还有R. 至于某种语言来说,一般都要讲究一些特别的算法,包含但不限于: 矩阵方面的计算 指数计算 对数计算 多项式运算 各类方程求解 总之.仅 ...

  6. appium+python解决每次运行代码都提示安装Unlock以及AppiumSetting的问题

    appium+python解决每次运行代码都提示安装Unlock以及AppiumSetting的问题(部分安卓机型) 1.修改appium-android-driver\lib下的android-he ...

  7. 高德API+Python解决租房问题(.NET版)

    源码地址:https://github.com/liguobao/58HouseSearch 在线地址:58公寓高德搜房(全国版):http://codelover.link:8080/ 周末闲着无事 ...

  8. Python的组合模式与责任链模式编程示例

    Python的组合模式与责任链模式编程示例 这篇文章主要介绍了Python的组合模式与责任链模式编程示例,组合模式与责任链模式都属于Python的设计模式,需要的朋友可以参考下 组合模式 我们把Com ...

  9. python的组合数据

    python的组合数据包括:1.列表list[   ] 2.元组tuple(),3.字典dict{"x":"y"},4.集合set{} 1.创造组合数据:均可直 ...

随机推荐

  1. Zepto学习笔记

    Zepto和jQuery的很多API都很一致,思路也很相似,我不会全都整理出来,只是把一些平时用到了的或者不同的地方需要注意一下的地方总结出来.另外,Zepto现在还不是很成熟,无论是对大小写的敏感还 ...

  2. 【CodeForces】671 C. Ultimate Weirdness of an Array

    [题目]C. Ultimate Weirdness of an Array [题意]给定长度为n的正整数序列,定义一个序列的价值为max(gcd(ai,aj)),1<=i<j<=n, ...

  3. mysql数据库 批量替换 某字段中的数据

    当数据库出现这种情况: 表名:area id name 1  太仓 2  太仓市 3  太仓市 ... ... 我需要把 name字段中 的太仓市 的“市“去掉 可以使用: update `area` ...

  4. 线程句柄和线程ID的区别

    ●CreateThread() API 用于创建线程. API 返回同时线程句柄,并通过参数得到线程标识符 (ID). 线程句柄有完全访问权创建线程对象. 运行线程时线程 ID 唯一标识线程在系统级别 ...

  5. Fiddler -工具使用介绍(附:拦截请求并修改返回数据)(转)

    一.Fiddler 介绍 Fiddler 是一个使用 C# 编写的 http 抓包工具.它使用灵活,功能强大,支持众多的 http 调试任务,是 web.移动应用的开发调试利器. 1,功能特点 同 H ...

  6. HMM的概述(五个基本元素、两个假设、三个解决的问题)

    一.五个基本元素 HMM是个五元组 λ =( S, O , π ,A,B) S:状态值集合,O:观察值集合,π:初始化概率,A:状态转移概率矩阵,B:给定状态下,观察值概率矩阵   二.两个假设 HM ...

  7. 利用pycharm运行scrapy以及scrapy的配置

    1.安装两个whl文件 https://pypi.python.org/pypi/Twisted 下载Twisted的whl文件 https://pypi.python.org/pypi/Scrapy ...

  8. C# 开发(创蓝253)手机短信验证码接口

    创蓝253: https://www.253.com/ #region 获取手机验证码(创蓝253) /// <summary> /// 获取手机验证码(创蓝253) /// </s ...

  9. vsftpd.conf 详解

    //不允许匿名访问 anonymous_enable=NO //设定本地用户可以访问.注意:主要是为虚拟宿主用户,如果该项目设定为NO那么所有虚拟用户将无法访问 local_enable=YES // ...

  10. What does “=>” mean in import in scala?(转自StackOverflow问答)

      As others have mentioned, it's an import rename. There is however one further feature that proves ...