码迷,mamicode.com
首页 > 编程语言 > 详细

01背包问题(回溯法)python实现

时间:2014-05-24 22:08:01      阅读:544      评论:0      收藏:0      [点我收藏+]

标签:01背包   python   回溯法   

        接上一篇,同样的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)

运行结果如下:

bubuko.com,布布扣


转载请注明:转自http://blog.csdn.net/littlethunder/article/details/26621427

01背包问题(回溯法)python实现,布布扣,bubuko.com

01背包问题(回溯法)python实现

标签:01背包   python   回溯法   

原文地址:http://blog.csdn.net/littlethunder/article/details/26621427

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!