我对我的程序有问题

var

a:array[0..2000,0..2000] of longint;

d:array[1..2000] of longint;

v:array[1..2000] of boolean;

max,n,k,x,y,i,j:longint;

function min(c,d:longint):longint;

begin

if c>d then

exit(d)

else exit(c);

end;

begin

read(n);

read(x,y,a[x,y]);

while x0 do

read(x,y,a[x,y]);

for i:=2 to n do

d[i]:=a[1,i];

for i:=2 to n do

begin

max:=0;

for j:=1 to n do

if (d[j]>max)and(not v[j]) then

begin

max:=d[j];

k:=j;

end;

v[k]:=true;

for j:=1 to n do

if (not v[j])and(min(a[k,j],d[k])>d[j]) then

d[j]:=min(a[k,j],d[k]);

end;

for i:=2 to n do

writeln(d[i]);

end.

Orz神牛

for j:=1 to n do

if (not v[j])and(min(a[k,j],d[k])>d[j]) then

d[j]:=min(a[k,j],d[k]);

这句是啥意思???

0 条评论

目前还没有评论...

信息

ID
1391
难度
6
分类
图结构 | 最短路 点击显示
标签
(无)
递交数
2970
已通过
823
通过率
28%
被复制
8
上传者