Python基于回溯法子集树模板解决取物搭配问题实例


Posted in Python onSeptember 02, 2017

本文实例讲述了Python基于回溯法子集树模板解决取物搭配问题。分享给大家供大家参考,具体如下:

问题

有5件不同的上衣,3条不同的裤子,4顶不同的帽子,从中取出一顶帽子、一件上衣和一条裤子作为一种搭配,问有多少种不同的搭配?

分析

换个角度看,现有头、身、腿三个元素,每个元素都有各自的几种状态。
头元素有['帽1', '帽2', '帽3', '帽4']共4种状态,身元素有['衣1', '衣2', '衣3', '衣4', '衣5']共5种状态,腿元素有['裤1', '裤2', '裤3']共3种状态
从头开始,自上而下,遍历每个元素的所有状态。

解的长度是固定的。

这里特别注意:每个元素的状态数目不同!!!

套用子集树模板即可

代码

```python
'''取物排列问题'''
n = 3 # 3个元素

头、身、腿3个元素各自的状态空间

a = [['帽1', '帽2', '帽3', '帽4'],
['衣1', '衣2', '衣3', '衣4', '衣5'],
['裤1', '裤2', '裤3']]
x = [0]*n # 一个解,长度固定,3元数组
X = [] # 一组解

冲突检测

def conflict(k):
return False # 无冲突

套用子集树模板

def match(k): # 到达第k个元素
global n, a, x, X
if k >= n: # 超出最尾的元素
  print(x)
  #X.append(x[:]) # 保存(一个解)
else:
  for i in a[k]: # 直接a[k],若间接则range(len(a[k]))。 遍历第k个元素的对应的所有选择状态,不同的元素状态数目不同
    x[k] = i
    if not conflict(k): # 剪枝
      match(k+1)

测试

match(0) # 从头(第0个元素)开始

效果图

Python基于回溯法子集树模板解决取物搭配问题实例

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python 文件和输入输出小结
Oct 09 Python
Python用Bottle轻量级框架进行Web开发
Jun 08 Python
Python获取SQLite查询结果表列名的方法
Jun 21 Python
python3利用Dlib19.7实现人脸68个特征点标定
Feb 26 Python
python如何为被装饰的函数保留元数据
Mar 21 Python
Python延时操作实现方法示例
Aug 14 Python
使用python根据端口号关闭进程的方法
Nov 06 Python
python爬取微信公众号文章的方法
Feb 26 Python
keras 自定义loss损失函数,sample在loss上的加权和metric详解
May 23 Python
Python代码需要缩进吗
Jul 01 Python
python类共享变量操作
Sep 03 Python
Python实现视频中添加音频工具详解
Dec 06 Python
Python基于回溯法子集树模板解决数字组合问题实例
Sep 02 #Python
Python基于回溯法子集树模板解决0-1背包问题实例
Sep 02 #Python
基于python 字符编码的理解
Sep 02 #Python
Python实现的简单模板引擎功能示例
Sep 02 #Python
Python实现Logger打印功能的方法详解
Sep 01 #Python
Python数据分析之如何利用pandas查询数据示例代码
Sep 01 #Python
Python使用回溯法子集树模板解决迷宫问题示例
Sep 01 #Python
You might like
计算2000年01月01日起到指定日的天数
2006/10/09 PHP
php文件上传表单摘自drupal的代码
2011/02/15 PHP
php 中self,this的区别和操作方法实例分析
2019/11/04 PHP
javascript开发技术大全-第1章javascript概述
2011/07/03 Javascript
jQuery中fadeIn、fadeOut、fadeTo的使用方法(图片显示与隐藏)
2013/05/08 Javascript
js判断鼠标同时离开两个div的思路及代码
2013/05/31 Javascript
Document:getElementsByName()使用方法及示例
2013/10/28 Javascript
点击显示指定元素隐藏其他同辈元素的方法
2014/02/19 Javascript
JQuery插件Quicksand实现超炫的动画洗牌效果
2015/05/03 Javascript
原生js实现模拟滚动条
2015/06/15 Javascript
js实现(全选)多选按钮的方法【附实例】
2016/03/30 Javascript
AngularJS 遇到的小坑与技巧小结
2016/06/07 Javascript
Sortable.js拖拽排序使用方法解析
2016/11/04 Javascript
vue学习笔记之v-if和v-show的区别
2017/09/20 Javascript
图文详解vue框架安装步骤
2019/02/12 Javascript
vue动态禁用控件绑定disable的例子
2019/10/28 Javascript
vue更改数组中的值实例代码详解
2020/02/07 Javascript
JavaScript实现点击切换功能
2021/01/27 Javascript
一起深入理解js中的事件对象
2021/02/06 Javascript
[28:28]Ti4 冒泡赛第二天NEWBEE vs NaVi 2
2014/07/15 DOTA
Python 拷贝对象(深拷贝deepcopy与浅拷贝copy)
2008/09/06 Python
基python实现多线程网页爬虫
2015/09/06 Python
好用的Python编辑器WingIDE的使用经验总结
2016/08/31 Python
Python实现随机选择元素功能
2017/09/14 Python
使用python的pandas库读取csv文件保存至mysql数据库
2018/08/20 Python
Python时间序列处理之ARIMA模型的使用讲解
2019/04/02 Python
pyqt5 禁止窗口最大化和禁止窗口拉伸的方法
2019/06/18 Python
解决keras,val_categorical_accuracy:,0.0000e+00问题
2020/07/02 Python
python使用正则表达式匹配txt特定字符串(有换行)
2020/12/09 Python
粉红色的鲸鱼:Vineyard Vines
2018/02/17 全球购物
康拓普公司Java笔面试
2016/09/23 面试题
八项规定整改方案
2014/02/21 职场文书
《小小竹排画中游》教学反思
2014/02/26 职场文书
幼儿园家长安全责任书
2014/07/22 职场文书
检讨书大全
2015/01/27 职场文书
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers