Làm thế nào tìm con đường ngắn nhất?

Trong cuộc sống hằng ngày chúng ta thường gặp vấn đề sau đây: Cần tìm con đường ngắn nhất đi từ điểm A đến điểm E như ở hình vẽ. Trên hình vẽ các điểm cuối mỗi đoạn đường là một địa điểm, đoạn thẳng chỉ con đường nối giữa hai điểm, con số trên mỗi đoạn thẳng chỉ cự ly của đoạn đường.

Trước hết xin dẫn ra phương pháp thông thường. Xem xét tất cả các tuyến đường có thể đi, tính toán tổng các cự ly, từ đó chọn được tuyến đường ngắn nhất. Từ A đến E có 3.3.3.1 đoạn đường có thể đi, mỗi tuyến đi cần thực hiện ba lần phép cộng, cần phải thực hiện 81 phép cộng. Ngoài ra còn phải tiến hành 26 lần phép so sánh, cuối cùng sẽ tìm được tuyến đường ngắn nhất là A → B2 → C2 → D3 → E. Cự ly tương ứng bằng 15.

Ta dễ dàng nhận thấy thực hiện như phương pháp thông thường quả là đơn giản nhưng để thực hiện lại không dễ vì phải qua nhiều địa điểm, thực hiện quá nhiều phép tính.

Vậy liệu có phương pháp nào khác không?

Giả sử ta chọn được con đường ngắn nhất là A → B2 → C2 → D3 → E thì đoạn đường nhỏ trong đó đi từ hai điểm của tuyến đường cũng phải là ngắn nhất, ví dụ C2 → D3 → E cũng phải là con đường ngắn nhất từ C2 đến E. Nếu không, khi dùng phản chứng ta phải tìm được một tuyến đường khác ngắn hơn và điều đó trái với giả thiết. Tuyến đường ngắn nhất như mô tả ở trên, chúng ta có thể bắt đầu từ cuối tuyến đường truy dần từng bước ta sẽ tìm được tuyến đường ngắn nhất từ A đến E.

Bước thứ nhất: Tìm đoạn đường ngắn nhất từ D đến E.

Từ D1, D2, D3 đến E có các tuyến f(D1) = 5, f(D2) = 8, f(D3) = 1. f(xi) biểu diễn cự ly ngắn nhất từ xi đến E.

Bước thứ hai: Xét đoạn đường ngắn nhất từ C đến E.

Xuất phát từ C1 có khả năng chọn đến D1, D2 hoặc D3.

trong đó, d(C1, D1) biểu diễn khoảng cách từ C1 đến D1, dễ dàng tìm thấy khoảng cách ngắn nhất là theo tuyến C1 → D3→ E.

Tương tự xuất phát từ C2 ta có

Và tuyến ngắn nhất là C2→D3 → E. Tương tự

Từ C3 tuyến ngắn nhất là C3 → D3 →E với f(C3) = 6

Cũng với lí do tương tự, ta tìm thấy f(B1) = 12 cho đoạn đường con B1 → C2 → D3 → E

và f(B2) = 7 cho đoạn đường con B2 → C2 → D3 → E

f(B3) = 12 cho đoạn đường con B1 → C__1 (hoặc C2) → D3 → E

Xuất phát từ A ta có:

Dựa vào quá trình tính toán, ta thấy số lượng phép toán giảm đi rất nhiều: chỉ cần 3.3 + 3.3 + 3 = 21 phép cộng và 3.2 + 3.2 + 2 = 14 phép so sánh. Nếu số địa điểm càng lớn thì ưu điểm của phương pháp càng rõ rệt. Dùng phương pháp này không chỉ cho thấy tìm được đường từ A đến E ngắn nhất mà còn biết được cự ly từ điểm này đến điểm khác của tuyến đường. Trong toán học, người ta gọi đây là phương pháp “giải pháp theo quy tắc động thái”.

“Quy tắc động thái” là phương pháp cho phép giải quyết nhanh bài toán tối ưu, do nhà toán học Mỹ Bellman đưa ra năm 1959. Đây là bài toán “tối ưu hoá” đã được phát triển thành ngành toán học mới. Phương pháp quy tắc động thái được phát huy rộng rãi trong các ngành kĩ thuật công trình, quản lí kinh tế, trong sản xuất công nghiệp và kĩ thuật quân sự và ngày càng được coi trọng, thậm chí còn được dùng trong việc chọn phạm vi trong máy tính. Bởi vì nếu dùng phương pháp thông thường thì đến cả máy tính cũng khó thực hiện hết được các phép tính.

Vì sao lần đầu tham gia vận động mạnh, cơ bắp thường phát sinh đau mỏi?

Người thường không hay vận động, một khi tham gia vận động mạnh, vì lượng vận động nhiều nên cục bộ cơ bắp có hiện tượng đau mỏi. Đó là điều rất tự...

Tại sao truyền thông không thể thiếu được multimedia?

Multimedia trong lĩnh vực truyền thông là một loại medium (phương tiện truyền thông) truyền thông khác với medium đơn nhất truyền thống. Nó được tạo...

Vì sao có bàn chân bằng?

Khi đi đường bằng chân trần, mỗi người sẽ để lại dấu chân. Ở giữa dấu chân bao giờ cũng có hình khuyết mặt trăng.

Vì sao phải bảo vệ môi trường?

Ngày nay, việc bảo vệ môi trường đã trở thành nhận thức chung của mọi người. Nhưng vì sao lại phải bảo vệ môi trường? Bảo vệ môi trường như thế nào?...

Tại sao sao Kim quay ngược chiều?

Sao Kim, còn được gọi là sao Hôm, hay sao Mai là hành tinh duy nhất trong hệ Mặt trời quay từ Đông sang Tây, trong khi tất cả các hành tinh khác đều...

Vì sao không nên tắm nắng nhiều?

Ở một số nước Âu, Mĩ, nhiều người đặc biệt thích phơi mình ở bãi biển để tắm nắng. Các cô gái còn phơi cho da biến thành màu nâu, cho đó là đẹp.

Thế nào là nền nông nghiệp hữu cơ?

Từ năm 1900, sau khi người Mỹ phát hiện ra máy cày dùng dầu mazut (dầu diezen), nhiều nước đã ra sức phát triển nền nông nghiệp hiện đại lấy “nông...

Vì sao phát điện bằng năng lượng Mặt Trời, phát điện bằng sức gió còn bị hạn chế?

Mặt Trời hàng năm cung cấp cho mặt đất một nguồn năng lượng tương đương với đốt cháy 1,3 x 1014 tấn than đá tiêu chuẩn, trong đó 30% bị phản xạ trở...

Tại sao mùa hè thì nóng, mùa đông thì lạnh?

Mùa hè nóng và mùa đông lạnh là do trục tự quay của trái đất nghiêng với mặt phẳng quỹ đạo của nó quanh mặt trời.