/ Vijos / 讨论 / 过河 /

有俩点不知道咋错的,大牛们帮帮忙!

program p1002;

var

l,s,t,m,i,j,mid,best,tt:longint;

a,b:array[1..100] of longint;

f:array[-100..50000] of longint;

ans:array[1..50000] of boolean;

begin

readln(l);

readln(s,t,m);

for i:=1 to m do

read(a[i]);

for i:=1 to m-1 do

for j:=i+1 to m do

if a[i]>a[j] then begin tt:=a[i];a[i]:=a[j];a[j]:=tt; end;

if a[1]>100 then mid:=(a[1] div 100-1)*100;

b[1]:=a[1]-mid;

for i:=1 to m-1 do

begin

if a-a[i]>100 then mid:=mid+((a-a[i]) div 100-1)*100;

b:=a-mid;

end;

for i:=1 to m do

ans[b[i]]:=true;

if l-a[m]>100 then mid:=mid+((l-a[m]) div 100-1)*100;

l:=l-mid;

for i:=1 to s-1 do

f[i]:=10000;

for i:=s to l+t-1 do

begin

best:=1000;

for j:=s to t do

if f=f[i] then best:=f[i];

writeln(best);

end.

1 条评论

  • @ 2010-03-27 20:07:52

    如果第i个点和第i-1个点距离超过了100,你将第i个点和第i+1个点给缩进了,但是后面的点没有,有可能影响到第i+2个点和第i+1个点的关系,你仔细想想。应该缩进i~m所有点

  • 1

信息

ID
1002
难度
7
分类
动态规划 点击显示
标签
递交数
25264
已通过
4390
通过率
17%
被复制
76
上传者