DP,比较恼的是题中没说明a、b的范围,不敢轻易用双循环
添加链接描述
#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int INF = 1e9 + 10;
int l1, l2, l3, c1, c2, c3, a, b, n;
int pri(int d){
if(d <= l1) return c1;
else if(d <= l2) return c2;
return c3;
}
int main()
{
while(cin>>l1>>l2>>l3>>c1>>c2>>c3>>a>>b>>n){
vector<ll>p(n + 1, 0);
vector<ll>dp(n + 1, INF); //dp[i]表示从第一个站到第i个站的最短距离
for(int i = 2; i <= n; i ++ ){
cin>>p[i]; //p[i]表示第1个站到第i个站的距离
}
p[1] = 0;
dp[a] = 0;
for(int i = a + 1; i <= b; i ++ ){ //这一次下车的站
for(int j = a; j < i; j ++ ){ //上一次下车的站
int d = p[i] - p[j]; //两个车站间的距离
if(p[i] - p[j] <= l3){
dp[i] = min(dp[i], dp[j] + pri(d));
}
}
}
cout<<dp[b]<<endl;
}
return 0;
}