⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dijkstra.dpr

📁 OI模板 很全
💻 DPR
字号:
{$R+,Q+,D+}
program Dijsktra;
uses
	Base, GraphGen, BinaryHeap, FibonacciHeap, PairHeap, Windows;
type
	TDist = array[1..MaxN] of TKey;
	TCheck = array[1..MaxN] of Boolean;
var
	Dist: TDist;
	Check: TCheck;

function Dijkstra: TKey;
var
	i: TIndex;
	Cur, Ptr: TIndex;
	Node: PFibonacciNode;
	Heap: TFibonacciHeap;
begin
	Heap.Create(N);
	for i := 1 to N do
	begin
		Check[i] := false;
		Heap.Insert(i, InfiniteValue);
		Dist[i] := InfiniteValue;
	end;
	Heap.DecreaseKey(S, 0);
	Dist[S] := 0;
	while not Check[T] do
	begin
		Node := Heap.Minimum;
		if Node = nil then Break;
		Cur := Node^.Index;

		Check[Cur] := true;
		Heap.DeleteMin;

		Ptr := Last[Cur];
		while Ptr > 0 do
		begin
			with Edge[Ptr] do
				if not Check[Adj] and (Dist[Adj] > Dist[Cur] + Weight) then
				begin
					Dist[Adj] := Dist[Cur] + Weight;
					Heap.DecreaseKey(Adj, Dist[Adj]);
				end;
			Ptr := Edge[Ptr].Prev;
		end;
	end;
	Result := Dist[T];
	Heap.Destory;
end;

function Dijkstra2: TKey;
var
	i: TIndex;
	Cur, Ptr: TIndex;
	Node: PBinaryNode;
	Heap: TBinaryHeap;
begin
	Heap.Create(N);
	for i := 1 to N do
	begin
		Check[i] := false;
		Heap.Insert(i, InfiniteValue);
		Dist[i] := InfiniteValue;
	end;
	Heap.DecreaseKey(S, 0);
	Dist[S] := 0;
	while not Check[T] do
	begin
		Node := Heap.Minimum;
		if Node = nil then Break;
		Cur := Node^.Index;

		Check[Cur] := true;
		Heap.DeleteMin;

		Ptr := Last[Cur];
		while Ptr > 0 do
		begin
			with Edge[Ptr] do
				if not Check[Adj] and (Dist[Adj] > Dist[Cur] + Weight) then
				begin
					Dist[Adj] := Dist[Cur] + Weight;
					Heap.DecreaseKey(Adj, Dist[Adj]);
				end;
			Ptr := Edge[Ptr].Prev;
		end;
	end;
	Result := Dist[T];
	Heap.Destory;
end;

function Dijkstra3: TKey;
var
	i: TIndex;
	Cur, Ptr: TIndex;
	Node: PPairNode;
	Heap: TPairHeap;
begin
	Heap.Create(N);
	for i := 1 to N do
	begin
		Check[i] := false;
		Heap.Insert(i, InfiniteValue);
		Dist[i] := InfiniteValue;
	end;
	Heap.DecreaseKey(S, 0);
	Dist[S] := 0;
	while not Check[T] do
	begin
		Node := Heap.Minimum;
		if Node = nil then Break;
		Cur := Node^.Index;

		Check[Cur] := true;
		Heap.DeleteMin;

		Ptr := Last[Cur];
		while Ptr > 0 do
		begin
			with Edge[Ptr] do
				if not Check[Adj] and (Dist[Adj] > Dist[Cur] + Weight) then
				begin
					Dist[Adj] := Dist[Cur] + Weight;
					Heap.DecreaseKey(Adj, Dist[Adj]);
				end;
			Ptr := Edge[Ptr].Prev;
		end;
	end;
	Result := Dist[T];
	Heap.Destory;
end;

procedure Main;
var
	Start: Int64;
begin
	Randomize;
	GenerateRandomSparse;
	Start := GetTickCount;
	Writeln(Dijkstra);
	Writeln(GetTickCount - Start);
	Start := GetTickCount;
	Writeln(Dijkstra2);
	Writeln(GetTickCount - Start);
	Start := GetTickCount;
	Writeln(Dijkstra3);
	Writeln(GetTickCount - Start);
end;
begin
	Main;
end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -