欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基于回溯法子集樹模板解決找零問題示例

 更新時(shí)間:2017年09月11日 11:17:19   作者:羅兵  
這篇文章主要介紹了Python基于回溯法子集樹模板解決找零問題,簡(jiǎn)單描述了找零問題并結(jié)合具體實(shí)例形式分析了Python使用回溯法子集樹模板解決找零問題的步驟、實(shí)現(xiàn)方法與相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Python基于回溯法子集樹模板解決找零問題。分享給大家供大家參考,具體如下:

問題

有面額10元、5元、2元、1元的硬幣,數(shù)量分別為3個(gè)、5個(gè)、7個(gè)、12個(gè)?,F(xiàn)在需要給顧客找零16元,要求硬幣的個(gè)數(shù)最少,應(yīng)該如何找零?或者指出該問題無解。

分析

元素——狀態(tài)空間分析大法:四種面額的硬幣看作4個(gè)元素,對(duì)應(yīng)的數(shù)目看作各自的狀態(tài)空間,遍歷狀態(tài)空間,其它的事情交給剪枝函數(shù)。

解的長(zhǎng)度固定:4

解的編碼:(x1,x2,x3,x4) 其中x1∈[0,1,2,3], x2∈[0,1,2,3,4,5], x3∈[0,1,2,...,7], x4∈[0,1,2,...,12]

求最優(yōu)解,增添全局變量:best_x, best_num

套用回溯法子集樹模板。

代碼

'''找零問題'''
n = 4
a = [10, 5, 2, 1] # 四種面額
b = [3, 5, 7, 12] # 對(duì)應(yīng)的硬幣數(shù)目(狀態(tài)空間)
m = 53 # 給定的金額
x = [0]*n  # 一個(gè)解(n元0-b[k]數(shù)組)
X = []  # 一組解
best_x = [] # 最佳解
best_num = 0 # 最少硬幣數(shù)目
# 沖突檢測(cè)
def conflict(k):
  global n,m, x, X, a, b, best_num
  # 部分解的金額已超
  if sum([p*q for p,q in zip(a[:k+1], x[:k+1])]) > m:
    return True
  # 部分解的金額加上剩下的所有金額不夠
  if sum([p*q for p,q in zip(a[:k+1], x[:k+1])]) + sum([p*q for p,q in zip(a[k+1:], b[k+1:])]) < m:
    return True
  # 部分解的硬幣個(gè)數(shù)超best_num
  num = sum(x[:k+1])
  if 0 < best_num < num:
    return True
  return False # 無沖突
# 回溯法(遞歸版本)
def subsets(k): # 到達(dá)第k個(gè)元素
  global n, a, b, x, X, best_x, best_num
  if k == n: # 超出最尾的元素
    #print(x)
    X.append(x[:]) # 保存(一個(gè)解)
    # 計(jì)算硬幣數(shù)目,若最佳,則保存
    num = sum(x)
    if best_num == 0 or best_num > num:
      best_num = num
      best_x = x[:]
  else:
    for i in range(b[k]+1): # 遍歷元素 a[k] 的可供選擇狀態(tài): 0, 1, 2, ..., b[k] 個(gè)硬幣
      x[k] = i
      if not conflict(k): # 剪枝
        subsets(k+1)
# 測(cè)試
subsets(0)
print(best_x)

效果圖

更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論