intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Tìm đường đi ngắn nhất với định tuyến Dijkstra

Chia sẻ: Nguyen My Love | Ngày: | Loại File: DOC | Số trang:3

1.164
lượt xem
197
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Bài viết này xin giới thiệu với các bạn mới làm quen với tin học và thuật giải một thuật toán đơn giản nhưng lại có hiệu quả rất lớn trong việc tìm đường đi ngắn nhất trong đồ thị. Đó là thuật toán Dijkstra. Đây là thuật toán đã đăng tải trên tạp chí tin học & nhà trường từ những số đầu tiên nhưng bài viết này sẽ đăng tải đầy đủ về bài toán, phương thức đưa ra thuật giải cũng như đoạn chương trình đầy đủ. Rất thích hợp với những bạn mới làm quen với những thuật toán kinh...

Chủ đề:
Lưu

Nội dung Text: Tìm đường đi ngắn nhất với định tuyến Dijkstra

  1. Tìm đường đi ngắn nhất với định tuyến Dijkstra Bài viết này xin giới thiệu với các bạn mới làm quen với tin học và thuật giải một thuật toán đơn giản nhưng lại  có hiệu quả rất lớn trong việc tìm  đường  đi ngắn nhất trong  đồ thị.  Đó là thuật toán Dijkstra.  Đây là thuật toán  đã đăng tải trên tạp chí tin học & nhà trường từ những số đầu tiên nhưng bài viết này sẽ đăng tải đầy đủ về bài   toán, phương thức đưa ra thuật giải cũng như đoạn chương trình đầy đủ. Rất thích hợp với những bạn mới làm   quen với những thuật toán kinh điển.  Dijkstra là thuật toán định tuyến đơn giản để tìm đường đi ngắn nh ất gi ữa 2 đi ểm b ất kỳ. Không m ất tính tổng quát, ta coi mỗi điểm (nút mạng) là một đỉnh c ủa một đồ thị, ta sẽ dùng thu ật toán Dijkstra đ ể giải quyết bài toán tìm đường đi ngắn nhất giữa 2 điểm như sau: Bài toán: Cho đồ thị G với tập đỉnh V và tập các cạnh E (đ ồ th ị có h ướng ho ặc vô h ướng). M ỗi c ạnh của đồ thị được gán một nhãn (giá trị không âm), nhãn này còn đ ược gọi là giá tr ị c ủa c ạnh. Cho tr ước một đỉnh xác định v, gọi là đỉnh nguồn. Tìm đường đi ngắn nh ất t ừ đ ỉnh v đ ến các đ ỉnh còn l ại c ủa G. (Tức là tìm đường đi từ v đến các đỉnh còn lại với tổng các giá c ủa các c ạnh trên đ ường đi là nh ỏ nh ất). Nếu như đồ thị có hướng thì đường đi này là đường đi có hướng. Thuật toán Dijkstra: Ta có thể giải bài toán bằng cách xác định m ột t ập h ợp S ch ứa các đ ỉnh mà khoảng cách ngắn nhất từ nó đến đỉnh nguồn v đã bi ết. Khởi đầu S = { V }. Sau đó t ại m ỗi b ước ta s ẽ thêm vào S các đỉnh mà khoảng cách từ nó đến v là ngắn nh ất. V ới gi ả thi ết r ằng m ỗi cung có m ột giá trị không âm thì ta luôn luôn tìm được một đường đi ngắn nhất như v ậy mà ch ỉ đi qua các đ ỉnh đã t ồn t ại trong S. Ðể dễ dàng chi tiết hóa giải thuật, giả sử G có n đỉnh và nhãn trên m ỗi cung đ ược l ưu trong mảng C, tức là C[i, j] bằng giá trị(có thể xem là độ dài) của cung (i, j). N ếu i và j không có cung n ối thì ta cho C[i, j] =Ġ. Ta sẽ dùng một mảng D có n phần t ử để l ưu đ ộ dài c ủa đ ường đi ng ắn nh ất t ừ v đ ến mỗi đỉnh của đồ thị. Khởi đầu thì giá trị này chính là đ ộ dài c ạnh (v, i), t ức D[i] = C[v, i]. T ại m ỗi b ước của giải thuật thì D[i] sẽ lưu độ dài đường đi ngắn nhất từ đỉnh v đến đỉnh i, đường đi này chỉ đi qua các đỉnh đã có trong S. Ðể cài đặt giải thuật dễ dàng, ta giả sử các đỉnh c ủa đ ồ th ị đ ược đánh s ố t ừ 1 đ ến n và đ ỉnh ngu ồn là đỉnh Dưới giải thuật để giải 1. đây là Dijkstra bài toán trên : procedure Dijkstra; begin S := [1] ; { S chỉ chứa đỉnh nguồn } for i:=2 to n do D[i] := C[1, i] ; { Khởi đầu các giá trị cho D } for i:=1 to n - 1 do begin Lấy đỉnh w trong V - S sao cho D[w] là nhỏ nhất ; Thêm w vào S ; for mỗi đỉnh u thuộc V - S do D[u] := Min (D[u], D[w] + C[w, u]) ; end; end;
  2. Nếu muốn lưu trữ lại các đỉnh trên đường đi ngắn nhất để có thể xây dựng lại đường đi này từ đỉnh nguồn đến các đỉnh khác, ta dùng một mảng P. Mảng này sẽ lưu P[u] = w với đỉnh u là đỉnh trước của đỉnh w trên đường đi ngắn nhất. Lúc khởi đầu ta cho P[u] = 1, với mọi u khác 1. Giải thuật Dijkstra ở trên sẽ được viết lại như sau : procedure Dijkstra ; begin S := [1] ; { S chỉ chứa đỉnh nguồn } for i:=2 to n do begin D[i] := C[1, i] ; { Khởi đầu các giá trị cho D } P[i] := 1 ; { Khởi đầu các giá trị cho P } end ; for i:=1 to n - 1 do begin Lấy đỉnh w trong V - S sao cho D[w] là nhỏ nhất ; Thêm w vào S ; for mỗi đỉnh u thuộc V - S do if (D[w] + C[w, u] < D [u]) then begin D[u] := D[w] + C[w, u] ; P[u] := w ; end ; end; end; Ví dụ : Áp dụng giải thuật Dijkstra cho đồ thị hình sau:
  3. procedure DijksTra; begin t:=false; t[u0]:=true; d[i]:=c[u0,i];{Neu khong co duong di thi d[i]=i’} k:=1;{Da ket nap duoc 1 dinh} while kdo begin {Tim min} min:=i’; for i:=1 to n do if (d[i]d[u]+c[u,i] then if not((d[i]=i’)and(d[u]=i’)and(c[u,i]=i’)) then begin d[i]:=d[u]+c[u,i]; truoc[i]:=u end end; if d[v0]=i’ then KhongCoDuongDi else QuayLaiMangTruocDeTimDuong end;
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2