Python基于回溯法解决01背包问题实例
2017-12-06 12:34
1011 查看
本文实例讲述了Python基于回溯法解决01背包问题。分享给大家供大家参考,具体如下:
同样的01背包问题,前面采用动态规划的方法,现在用回溯法解决。回溯法采用深度优先策略搜索问题的解,不多说,代码如下:
bestV=0 curW=0 curV=0 bestx=None def backtrack(i): global bestV,curW,curV,x,bestx if i>=n: if bestV<curV: bestV=curV bestx=x[:] else: if curW+w[i]<=c: x[i]=True curW+=w[i] curV+=v[i] backtrack(i+1) curW-=w[i] curV-=v[i] x[i]=False backtrack(i+1) if __name__=='__main__': n=5 c=10 w=[2,2,6,5,4] v=[6,3,5,4,6] x=[False for i in range(n)] backtrack(0) print(bestV) print(bestx)
运行结果如下:
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- Python基于动态规划算法解决01背包问题实例
- Python基于回溯法子集树模板解决取物搭配问题实例
- Python基于回溯法子集树模板解决全排列问题示例
- Python基于回溯法子集树模板解决旅行商问题(TSP)实例
- Python基于回溯法子集树模板解决m着色问题示例
- Python基于回溯法子集树模板解决找零问题示例
- Python基于回溯法子集树模板解决最佳作业调度问题示例
- Python基于回溯法子集树模板解决野人与传教士问题示例
- 基于python发送邮件的乱码问题的解决办法
- Python使用回溯法子集树模板解决迷宫问题示例
- 回溯法解决01背包问题
- Linux管理工作,实例讲解工作中使用ssh证书登录的实际流程,讲解ssh证书登录的配置原理,基于配置原理,解决实际工作中,windows下使用SecureCRT证书登录的各种问题,以及实现hadoo
- java编程经典案例之基于斐波那契数列解决兔子问题实例
- Java基于栈方式解决汉诺塔问题实例【递归与非递归算法】
- 回溯法解决01背包问题
- python - 用遗传算法解决0-1背包问题,遗传算法是基于概率论的,因此不一定能一次命中最优解
- 01背包问题(回溯法)python实现
- python获取文件绝对路径解决找不到文件句柄的问题实例(readConfig.py)V1.2
- python获取文件绝对路径解决找不到文件句柄的问题实例(readConfig.py)V1.2
- PHP回溯法解决0-1背包问题实例分析