204512-53/lecture7
จดบันทึกคำบรรยายโดย:
5314550032 นาย กิตติกานต์ ดวงประภา
5314550041 นาย เกียรติชุมพล สุทธิศิริกุล
5314550059 นาย ฉนานนท์ ตันสกุล
Shortest Paths
มี โดยที่
มี : โดยที่
ให้ สำหรับ ใดๆ แทนระยะทางที่สั้นที่สุดจาก ไป
Lemma: ถ้าให้ เป็นระยะทางจาก ไป บน แล้ว จะเป็น shortest path tree ก็ต่อเมื่อ(if and only if) สำหรับทุกๆ เส้นเชื่อม
พิจารณาตัวอย่าง
จากรูปข้างบน ในที่นี้ ไม่ใช่ shortest path แล้ว ถ้าเราอยากทราบ shortest path เราก็บอก parent ของ ให้วิ่งไปหา shortest path ทางอื่น อย่าวิ่งผ่านมาที่ (นี่คือการ update shortest path)
Framework ของการหา shortest path
- ทุกๆ โหนดเก็บ parent , โหนด เก็บ ที่เป็น parent ใน candidate shortest path tree
(เริ่มต้น)
- ทุกๆ โหนด เก็บ ซึ่งแทนระยะทางที่สั้นที่สุด"เท่าที่ทราบ" จาก ไป
(เริ่มต้น)
LABELING STEP:
เลือกเส้นเชื่อม ที่ จากนั้น
Ford's algorithm -> ทำ labeling step ไปเรื่อยๆ
ตัวอย่าง
Step เริ่มต้น และ ของโหนดอื่นๆ มีค่าเป็น
Step ต่อมา ค่อยๆ ปรับ และ parent (หัวลูกศรชี้หา parent)
Claim 1: ถ้า , จะมี path จาก ไป ที่มีความยาว
Claim 2: ถ้า Ford's Algorithm ทำงานจบ, ระยะทางที่สั้นที่สุดจาก ไป
(นั่นคือ ระยะที่ estimate ได้ จะไม่มากไปกว่าระยะทางที่สั้นที่สุด)
ถ้า algorithm ทำงานจบ เราจะรู้ว่า
Proof: พิจารณาโหนด ใดๆ ให้ path เป็น shortest path จาก ไป
ดังนั้น
เนื่องจาก Ford's algorithm ทำงานจบ เราจะได้ว่า ,
นั่นคือ
จะได้ว่า
= = = (เนื่องจาก) = (เนื่องจาก )
เมื่อนำ Claim 1 มารวมกับ Claim 2 เราจะสรุปได้ว่า ถ้า Ford's algorithm ทำงานจบ เราจะได้ระยะทาง shortest path
คำถามต่อมาคือ เราจะรู้ได้ยังไงว่า algorithm จะทำงานจนจบ
Claim 3: ถ้ามี Negative cycle ที่ไปถึงได้จาก , algorithm จะทำงานไม่จบ
เนื่องจาก labeling step ของ Ford อิงกับเส้นเชื่อมเป็นหลัก ดังนั้นเพื่อให้พิสูจน์ได้ เราจะปรับโครงสร้างสักเล็กน้อย ซึ่งจะอิงกับ node เป็นหลัก พิจารณารูปข้างล่าง
แต่ละโหนดจะมี 3 state
- UNLABELED หมายถึง โหนดที่ยังไม่เคยถูกกระทำใดๆ เลย
- LABELED หมายถึง โหนดที่โดน update แล้ว
- SCANNED หมายถึง โหนดที่โดน update แล้ว และได้มีการพิจารณาทุกเส้นเชื่อมที่ติดกับโหนดนั้นและกระจายค่าไปให้คนอื่นแล้ว
SCANNING STEP:
เลือก labeled node u , scan u แล้วเปลี่ยนสถานะของ u ให้เป็น SCANNED
scan (u) for all edge(u,v) if D(u) + l(u,v) < D(v) D(v) <- D(u) + l(u,v) p(v) <- u เปลี่ยนสถานะ v ให้เป็น LABELED
ดูตัวอย่างตามรูปข้างล่าง มีกราฟ
เมื่ออัลกอริทึมเริ่มทำงาน ตามรูป โหนด s มีสถานะเป็น scanned ส่วนโหนด a มีสถานะเป็น labeled
ถ้ามีการ update โหนดที่เป็น scanned อยู่แล้ว โหนดนั้นก็จะกลับมาสู่สถานะ labeled อีกครั้ง
เมื่อทุกโหนดเปลี่ยนสถานะเป็น scanned ทั้งหมด อัลกอรึทึมนี้ก็จะถือว่าทำงานจบ
จะเห็นว่า มีความเป็นไปได้ที่เราจะต้องทำการ scan โหนดบางโหนดมากกว่าหนึ่งครั้ง ดังนั้นถ้าเราสามารถจัดลำดับของการ scan ที่ทำให้แต่ละโหนดได้รับการ scan แค่ครั้งเดียวก็จะเป็นการดี
Directed Acyclic Graph (DAG)
กราฟที่มีทิศทาง G จะเป็น DAG ก็ต่อเมื่อ G ไม่มี cycle
ให้กราฟ , ลำดับของโหนด จะเป็น topological order ถ้าไม่มีเส้นเชื่อม ที่
ถ้ากราฟใดๆ มี topological order ก็สรุปได้ว่าเราสามารถไล่ scan โหนดไปในทิศทางเดียวโดยที่ไม่ต้องย้อนกลับมา scan โหนดเดิมอีกได้
รูปข้างล่างแสดงตัวอย่างของกราฟที่ไม่มี topological order
นั่นคือ ถ้ากราฟมี cycle กราฟนั้นจะไม่มี topological order
คำถาม ถ้ากราฟไม่มี cycle กราฟนั้นจะมี topological order รึเปล่า
ตอบ มีเสมอ สามารถพิสูจน์ได้โดยแสดงอัลกอริทึม topological sort
Topological Sort - โหนดที่ไม่มี edge ใดๆ ชี้หาเรียกว่า "source" - วิธีการคือ วิ่งหา source แล้วก็ลบโหนดนั้นทิ้ง แล้วก็ไล่หา source ตัวถัดไปแล้วก็ลบโหนดนั้นทิ้งอีก ทำเช่นนี้ไปเรื่อยๆ ลำดับในการลบที่ได้คือ topological order
พิสูจน์ว่า DAG ใดๆ มี topological order โดยใช้วิธีการ contradiction เนื่องจากกราฟมีโหนดจำนวนจำกัด ถ้าหากอัลกอริทึม topological sort สามารถทำงานไปได้เรื่อยๆ ไม่จบ แสดงว่ากราฟนั้นมี cycle ซึ่งไม่เป็น DAG
Dijkstra's Algorithm ใช้กับกราฟที่ไม่มี negative cycle
เป็นวิธีการแบบหนึ่งที่ใช้สำหรับหา shortest path โดยใช้หลักการ เลือกสแกน labeled node u ที่มี น้อยที่สุด ซึ่งทำให้รับประกันได้ว่าเมื่อเราสแกนโหนดนี้ไปแล้วจะไม่ต้องกลับมาสแกนที่โหนดเดียวกันอีก
- เลือก ที่มีค่า น้อยที่สุด _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ขั้นตอนนี้เรียกว่าการทำ Extract Min
- เลือก ที่มีค่า น้อยที่สุด _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ขั้นตอนนี้เรียกว่าการทำ Extract Min
-
- _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ขั้นตอนนี้เรียกว่าการทำ Decrease Key
- เปลี่ยนสถานะ ให้เป็น Labeled
- _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ ขั้นตอนนี้เรียกว่าการทำ Decrease Key
Data structure ที่เหมาะนำมาใช้กับ algorithm นี้คือ priority queue , ถ้ามี priority queue ที่สามารถ
- Extract Min ได้ในเวลา
- Decrease Key ได้ในเวลา
- Extract Min ได้ในเวลา
ดังนั้น เมื่อวิเคราะห์เวลาการทำงานของ Dijkstra's algorithm จะได้ว่า algorithm ทำงานในเวลา
เมื่อวิเคราะห์เวลาการทำงานของ Dijkstra's algorithm เมื่อใช้ data structure แบบอื่นๆ จะได้ตามตารางข้างล่าง
Array | |||
Heap | |||
Fibonacci Heap | amortized |
General Case (general weights)
- Bellman-Ford-Moore
-
-
Claim
หลังการทำงานของ BFM ไป i รอบ โหนด ที่มี shortest path จาก ไป ไม่เกิน i เส้น จะมี
Thm
ถ้ากราฟไม่มี negative cycle, BFM จะทำงานไม่เกิน n-1 รอบ
ดังนั้น BFM ทำงานในเวลา