Thuật toán Edmonds–Karp

Trong khoa học máy tínhlý thuyết đồ thị, thuật toán Edmonds–Karp là một trường hợp đặc biệt của thuật toán Ford–Fulkerson cho việc tìm luồng cực đại trong mạng. Nó có độ phức tạp tính toán O(V E2). Độ phức tạp tính toán của nó cao hơn của thuật toán gán lại nhãn-lên đầu (O(V3)), nhưng nó thường chạy nhanh hơn trên đồ thị thưa. Thuật toán này được xuất bản lần đầu tiên bởi Yefim (Chaim) Dinic năm 1970[1] và một cách độc lập bởi Jack EdmondsRichard Karp năm 1972[2]. Thuật toán Dinic có thêm một số cải tiến giúp giảm thời gian chạy xuống O(V2E).

Thuật toán

[sửa | sửa mã nguồn]

Cấu trúc của thuật toán giống hệt như thuật toán Ford–Fulkerson, chỉ khác cách lựa chọn đường tăng luồng. Đường tăng luồng được chọn là đường tăng có ít cung nhất. Có thể tìm đường tăng này bằng tìm kiếm theo chiều rộng. Có thể chứng minh thời gian chạy của thuật toán là O(VE2) như sau. Thời gian để tìm mỗi đường tăng là O(E). Sau mỗi lần tăng luồng, ít nhất một cung của đồ thị trở thành bão hòa. Mỗi lần một cung trong E trở nên bão hòa (một cung có thể trở thành bão hòa nhiều lần), khoảng cách từ nguồn tới cung bị bão hòa tăng lên ít nhất 1 so với lần cuối cùng nó bị bão hòa trước đó. Khoảng cách này không bao giờ vượt quá V. Một tính chất nữa là khoảng cách từ nguồn tới một đỉnh bất kì là không giảm trong suốt quá trình tăng luồng. Có thể tham khảo một chứng minh đơn giản cho tính chất này ở Cormen và đồng nghiệp (2001). Như vậy số lần tăng luồng là không quá O(VE) và thời gian chạy là O(VE2).

Xem mô tả chi tiết hơn tại Thuật toán Ford-Fulkerson

Xét một mạng gồm bảy đỉnh, đỉnh phát A, đỉnh thu G, và khả năng thông qua được cho trong hình dưới đây:

Trong cặp số trên mỗi cung, là luồng hiện tại, và khả năng thông qua. Khả năng thông qua còn dư từ đến , hiệu của khả năng thông qua và luồng hiện tại. Nếu luồng từ đến là âm, nó làm tăng khả năng thông qua còn dư từ đến .

Khả năng thông qua Đường
Mạng thu được












Chú ý là chiều dài đường tăng luồng (màu đỏ) không bao giờ giảm. Đường tăng tìm được luôn là ngắn nhất có thể. Luồng tìm được bằng tổng khả năng thông qua của lát cắt cực tiểu trong đồ thị chia cắt đỉnh phát và đỉnh thu. Có đúng một lát cắt nhỏ nhất trong đồ thị này, chia tập hợp đỉnh thành , và có khả năng thông qua

  1. ^ Dinic, E. A. (1970). “Algorithm for solution of a problem of maximum flow in a network with power estimation”. Soviet Math. Doklady. Doklady. 11: 1277–1280.
  2. ^ Edmonds, Jack; Karp, Richard M. (1972). “Theoretical improvements in algorithmic efficiency for network flow problems”. Journal of the ACM. Association for Computing Machinery. 19 (2): 248–264. doi:10.1145/321694.321699.

Tham khảo

[sửa | sửa mã nguồn]
Chúng tôi bán
Bài viết liên quan
Ước mơ gấu dâu và phiên bản mini vô cùng đáng yêu
Ước mơ gấu dâu và phiên bản mini vô cùng đáng yêu
Mong ước nho nhỏ về vợ và con gái, một phiên bản vô cùng đáng yêu
Renner & Vật Phẩm Thay Đổi Chủng Tộc
Renner & Vật Phẩm Thay Đổi Chủng Tộc
rong các tập gần đây của Overlord đã hé lộ hình ảnh Albedo trao cho Renner một chiếc hộp ji đó khá là kì bí, có khá nhiều ae thắc mắc hỏi là Albedo đã tặng thứ gì cho cô ấy và tại sao lại tặng như vậy
Nhân vật Yui trong Jigokuraku
Nhân vật Yui trong Jigokuraku
Yui (結ゆい) là con gái thứ tám của thủ lĩnh làng Đá và là vợ của Gabimaru.
14 đỉnh núi linh thiêng nhất thế giới (phần 2)
14 đỉnh núi linh thiêng nhất thế giới (phần 2)
Là những vị khách tham quan, bạn có thể thể hiện sự kính trọng của mình đối với vùng đất bằng cách đi bộ chậm rãi và nói chuyện nhẹ nhàng