hdu2059DP之龟兔赛跑

思路:定义从i->j为在第i个站点充完电直接到达第j个站点(假设终点为第n+1个站点),i可以使小于j的任何站点,j从1增加到第n+1,所以time[n+1]=min(time[n+1],time[i]+T),T为从i到j的所花的时间.


#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<queue>
#include<algorithm>
#include<map>
#include<iomanip>
#define INF 99999999
using namespace std;

const int MAX=102;
double Time[MAX],p[MAX];//time表示到达从第i个充电站充完电直达第i个充电站所需要的最少时间

int main(){
	int n;
	double c,t,vr,vt1,vt2,l;
	while(cin>>l){
		cin>>n>>c>>t>>vr>>vt1>>vt2;
		for(int i=1;i<=n;++i)cin>>p[i];
		p[n+1]=l;
		for(int i=1;i<=n+1;++i)Time[i]=INF;
		for(int i=1;i<=n+1;++i){
			for(int j=0;j<i;++j){//通过第j个充电站到达第i个充电站 
				double s=p[i]-p[j];
				double T=s>c ? c/vt1+(s-c)/vt2 : s/vt1;
				if(j)T+=t;
				Time[i]=min(Time[i],Time[j]+T);
			}
		}
		if(Time[n+1]<=l/vr)cout<<"What a pity rabbit!"<<endl;
		else cout<<"Good job,rabbit!"<<endl;
	}
} 
以下是我的另一种想法:从第i个充电站到达第i+1个充电站每次选择在第i个充电站充电与不充电所要花的最少时间

不过提交是错的,跪求路过的大神帮忙给一个错误数据吧,我找了好久都没找到可怜

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<queue>
#include<algorithm>
#include<map>
#include<iomanip>
#define INF 99999999
using namespace std;

const int MAX=102;
double p[MAX];

int main(){
	int n;
	double c,t,vr,vt1,vt2,l;
	while(cin>>l){
		cin>>n>>c>>t>>vr>>vt1>>vt2;
		for(int i=0;i<n;++i)cin>>p[i];
		p[n]=l;
		double time=p[0]/vt1,way=c-p[0];
		if(way<0)time=(p[0]-c)/vt2+c/vt1,way=0;
		for(int i=0;i<n;++i){
			double s=p[i+1]-p[i];
			if(t+min(s,c)/vt1+max(0.0,s-c)/vt2<=min(s,way)/vt1+max(0.0,s-way)/vt2){
				time+=t+min(s,c)/vt1+max(0.0,s-c)/vt2;
				way=max(0.0,c-s);
			}
			else{
				time+=min(s,way)/vt1+max(0.0,s-way)/vt2;
				way=max(0.0,way-s);
			}
		}
		if(time>l/vr)cout<<"Good job,rabbit!"<<endl;
		else cout<<"What a pity rabbit!"<<endl;
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值