ในบทความนี้ เราจะเรียนรู้เกี่ยวกับวิธีแก้ปัญหาตามที่ระบุด้านล่าง
แจ้งปัญหา − เราได้รับไม้เท้าที่มีความยาว n และอาร์เรย์ของราคาที่มีราคาของทุกชิ้นที่มีขนาดเล็กกว่า n เราจำเป็นต้องกำหนดมูลค่าสูงสุดที่ได้มาโดยการตัดท่อนไม้และขายชิ้นส่วน
เราจะใช้วิธีการเขียนโปรแกรมแบบไดนามิกในการแก้ปัญหา
ทีนี้มาดูวิธีแก้ปัญหาในการใช้งานด้านล่างกัน:
ตัวอย่าง
# A Dynamic Programming solution for Rod cutting problem
INT_MIN = -32767
# cut function
def cutRod(price, n):
val = [0 for x in range(n + 1)]
val[0] = 0
# bottom up manner
for i in range(1, n + 1):
max_val = INT_MIN
for j in range(i):
max_val = max(max_val, price[j] + val[i-j-1])
val[i] = max_val
return val[n]
# main
arr = [2, 4, 7, 9, 11, 16, 16, 21]
size = len(arr)
print("Maximum Obtainable Value is " + str(cutRod(arr, size))) ผลลัพธ์
Maximum Obtainable Value is 21

ตัวแปรทั้งหมดได้รับการประกาศในขอบเขตท้องถิ่นและการอ้างอิงของตัวแปรนั้นดูได้จากรูปด้านบน
บทสรุป
ในบทความนี้ เราได้เรียนรู้เกี่ยวกับวิธีการสร้างโปรแกรม Python สำหรับการตัดไม้เท้า