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)

执行结果例如以下:



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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM