เมื่อจำเป็นต้องค้นหาสตริงย่อยทั่วไปที่ยาวที่สุดโดยใช้การเขียนโปรแกรมแบบไดนามิกด้วยวิธีการจากล่างขึ้นบน สามารถกำหนดวิธีการที่คำนวณวิธีแก้ปัญหาขนาดเล็กลงได้ ผลลัพธ์ของปัญหาเล็กๆ เหล่านี้ไม่จำเป็นต้องคำนวณซ้ำแล้วซ้ำอีก แต่สามารถเข้าถึงได้เมื่อจำเป็น ซึ่งจะนำไปสู่การพัฒนาแนวทางแก้ไขปัญหาที่ใหญ่กว่าในมือ
ด้านล่างนี้เป็นการสาธิตสำหรับสิ่งเดียวกัน -
ตัวอย่าง
def compute_lcw(string_1, string_2):
val = [[-1]*(len(string_2) + 1) for _ in range(len(string_1) + 1)]
for i in range(len(string_1) + 1):
val[i][len(string_2)] = 0
for j in range(len(string_2)):
val[len(string_1)][j] = 0
lcw_i = lcw_j = -1
lcw_len = 0
for i in range(len(string_1) - 1, -1, -1):
for j in range(len(string_2)):
if string_1[i] != string_2[j]:
val[i][j] = 0
else:
val[i][j] = 1 + val[i + 1][j + 1]
if lcw_len < val[i][j]:
lcw_len = val[i][j]
lcw_i = i
lcw_j = j
return lcw_len, lcw_i, lcw_j
string_1 = 'bull'
string_2 = 'bullied'
lcw_len, lcw_i, lcw_j = compute_lcw(string_1, string_2)
print("The longest common substring is : ")
if lcw_len > 0:
print(string_1[lcw_i:lcw_i + lcw_len]) ผลลัพธ์
The longest common substring is : bull
คำอธิบาย
- มีการกำหนดเมธอดชื่อ 'compute_lcw' ซึ่งรับสองสตริงเป็นพารามิเตอร์
- สตริงทั้งสองถูกวนซ้ำ และตรวจสอบเพื่อดูว่าพบสตริงที่ตรงกันในทั้งสองสตริงหรือไม่
- แม้เมื่อพบอักขระตัวเดียว อักขระนั้นก็ยังถูกเก็บไว้ในตัวแปรอื่น
- เมื่อสิ่งนี้ดำเนินต่อไปจนถึงจุดสิ้นสุดของสตริง สตริงอื่นจะเหมือนกับสตริงทั้งสองนี้
- มีการกำหนดสองสตริง และมีการเรียกเมธอดโดยการส่งผ่านสองสตริงนี้
- ข้อมูลการดำเนินการนี้ถูกกำหนดให้กับตัวแปร
- จากนั้นจะแสดงเป็นเอาต์พุตบนคอนโซล