标签:
题目描述 Description
话说adamyi编的Windows 2013超时了(- -!),所以他不得不在自己家门口亲眼见证这个电影般的场景。虽然他不想错过这个美妙的时刻,但是他的肚子一再抗议,要求先吃完这最后的晚餐。
现在adamyi准备依次吃n道菜。但是他只使用勺子和筷子吃,勺子和筷子可以交替使用,但是同一种菜只能用一种餐具,在开饭前他拿的是筷子。用勺子和筷子吃第i道菜的时间分别是a_i和b_i。吃第i道菜之前筷子和勺子交换的时间为c_i。
现在请你告诉adamyi按他的计划依次吃完这n道菜,最小需要多少时间。
一个数,最短时间
3
20 40 20
10 4 25
90 100 5
样例输出 Sample Output
139
一道比较水的dpvar f:array[1..100,1..2]of longint;
a,b,c:array[1..100]of longint;
i,j,k:longint;
m,n:longint;function min(x,y:longint):longint;
begin if x>y
then exit(y)
else exit(x);
end;
begin readln(n);
for i:=1 to n do
readln(a[i],b[i],c[i]);
f[1,1]:=a[1];
f[1,2]:=b[1];
for i:=2 to n do
for j:=1 to 2 do
begin f[i,1]:=min(f[i-1,1]+a[i],f[i-1,2]+c[i]+a[i]);
f[i,2]:=min(f[i-1,2]+b[i],f[i-1,1]+c[i]+b[i]);
end;
writeln(min(f[n,1],f[n,2]));
end.
标签:
原文地址:http://www.cnblogs.com/spiderKK/p/4337861.html