สมมุติว่าเรามีต้นไม้ที่มีจำนวนโหนดทั้งหมดตั้งแต่ 1 ถึง n แต่ละโหนดมีค่าจำนวนเต็ม ตอนนี้ ถ้าเราลบขอบออกจากทรี ความแตกต่างในผลรวมของค่าโหนดของทรีย่อยทั้งสองจะต้องน้อยที่สุด เราต้องหาและคืนค่าความแตกต่างขั้นต่ำระหว่างทรีย่อยดังกล่าว เราให้ต้นไม้เป็นชุดของขอบ และมีค่าของโหนดด้วย
ดังนั้น หากอินพุตเป็น n =6, edge_list =[[1, 2], [1, 3], [2, 4], [3, 5], [3, 6]], ค่า =[15, 25, 15, 55, 15, 65] แล้วเอาท์พุตจะเป็น 0

หากนำขอบ (1,2) ออก ผลรวมของน้ำหนักจะกลายเป็น 80, 110 ส่วนต่างคือ 30
หากนำขอบ (1,3) ออก ผลรวมของน้ำหนักจะกลายเป็น 95, 95 ส่วนต่างคือ 0
หากนำขอบ (2,4) ออก ผลรวมของน้ำหนักจะกลายเป็น 55, 135 ส่วนต่างคือ 80
หากนำขอบ (3,5) ออก ผลรวมของน้ำหนักจะกลายเป็น 15, 175 ส่วนต่างคือ 160
หากนำขอบ (3,6) ออก ผลรวมของน้ำหนักจะกลายเป็น 65, 125 ส่วนต่างคือ 60
ดังนั้นน้ำหนักขั้นต่ำคือ 0
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
- adj_list :=รายการใหม่ของขนาด n ที่มีรายการว่าง
- สำหรับแต่ละขอบใน edge_list ให้ทำ
- u :=edge[0]
- v :=edge[1]
- แทรก v-1 ที่ส่วนท้ายของ adj_list[u-1]
- แทรก u-1 ที่ส่วนท้ายของ adj_list[v-1]
- value_list :=รายการใหม่ของขนาด n เริ่มต้นด้วย 0s
- not_visited :=แผนที่ใหม่ขนาด i โดยที่ i คือจำนวนรายการที่ไม่ว่างเปล่าใน adj_list
- ในขณะที่ not_visited นั้นไม่ว่างเปล่า ให้ทำ
- สำหรับทุกๆ ฉันใน not_visited ทำ
- value_list[i] :=value_list[i] + ค่า[i]
- ถ้าความยาวของ (adj_list[i]) ไม่ใช่ศูนย์ ดังนั้น
- ลบ i จาก adj_list[adj_list[i, 0]]
- value_list[adj_list[i, 0]] :=value_list[adj_list[i, 0]] + value_list[i]
- สำหรับทุกๆ ฉันใน not_visited ทำ
- ถ้า len(adj_list[i]) และ len(adj_list[adj_list[i, 0]]) ==1 แล้ว
- not_visited :=รายการใหม่ที่มี adj_list[i, 0]
- ถ้า len(adj_list[i]) และ len(adj_list[adj_list[i, 0]]) ==1 แล้ว
- สำหรับทุกๆ ฉันใน not_visited ทำ
- return_val :=|sum(values) - 2 * value_list[0]|
- สำหรับฉันในช่วง 1 ถึง n ทำ
- decision_val :=|sum(values) - 2 * value_list[i]|
- ถ้าคำตัดสิน_val
- return_val :=การตัดสินใจ_val
ตัวอย่าง
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
def solve(n, edge_list, values):
adj_list = [[] for i in range(n)]
for edge in edge_list:
u = edge[0]
v = edge[1]
adj_list[u-1].append(v-1)
adj_list[v-1].append(u-1)
value_list = [0] * n
not_visited = {i for i in range(n) if len(adj_list[i]) == 1}
while(len(not_visited)):
for i in not_visited:
value_list[i] += values[i]
if(len(adj_list[i])):
adj_list[adj_list[i][0]].remove(i)
value_list[adj_list[i][0]] += value_list[i]
not_visited = {adj_list[i][0] for i in not_visited if
len(adj_list[i]) and len(adj_list[adj_list[i][0]]) == 1}
return_val = abs(sum(values) - 2 * value_list[0])
for i in range(1, n):
decision_val = abs(sum(values) - 2 * value_list[i])
if decision_val < return_val:
return_val = decision_val
return return_val
print(solve(6, [[1, 2], [1, 3], [2, 4], [3, 5], [3, 6]], [10, 20, 10, 50, 10, 60])) อินพุต
6, [[1, 2], [1, 3], [2, 4], [3, 5], [3, 6]], [10, 20, 10, 50, 10, 60]
ผลลัพธ์
0