hdu 2059

ps:终于解决了。。。。卡了我好久。最后用了DP。然后还有记忆化搜索优化了一下。终于AC了

思路:要计算dp[n](就是到第n个站的最短时间,也就是最优方案),必须知道dp[0]到dp[n-1]

设j是上一个站的充电,j从0开始循环,找出最优充电站,一直循环到n-1.然后取这里面的最小值.

代码:

#include "stdio.h"
#include "string.h"
int L,N,C,T,VR,VT1,VT2;
int p[110];
double dd[110];
double dp(int n){
    int i;
    if(n==0) return 0.0;
    if(dd[n]>0.0) return dd[n];
    int len;
    double time,min;
    min=100000000.0;
    for(i=0;i<n;i++){
        len=p[n]-p[i];
        if(len>=C){
            time=(double)(len-C)/VT2+(double)C/VT1;
        }
        else{
            time=(double)len/VT1;
        }
        if(i) time+=T;
        if(dp(i)+time<min){
            min=dp(i)+time;
        }
    }
    return dd[i]=min;
}
int main(){
    int i;
    double time2;
    while(~scanf("%d",&L)){
        scanf("%d%d%d",&N,&C,&T);
        scanf("%d%d%d",&VR,&VT1,&VT2);
        memset(dd,-1,sizeof(dd));
        for(i=1;i<=N;i++){
            scanf("%d",&p[i]);
        }
        p[0]=0;
        p[N+1]=L;
        time2=(double )L/VR;
        if(dp(N+1)>time2*1.0) printf("Good job,rabbit!\n");
        else printf("What a pity rabbit!\n");
    }
    return 0;
}
时间: 2024-08-25 03:58:20

hdu 2059的相关文章

HDU 2059 龟兔赛跑

题意:中文题,不解释. 思路:将长度为L分为n+2段:0,p[1],p[2]--,p[n],L. dp[i]为乌龟到第 i 段的最小时间, 乌龟可以再0~i-1段选择充电后到达 i 的最小时间,然后分类讨论下. #include<cstdio> #include<stdlib.h> #include<string.h> #include<string> #include<map> #include<cmath> #include<

HDU - 2059 龟兔赛跑(多阶段决策dp)

http://acm.hdu.edu.cn/showproblem.php?pid=2059 初始把起点和终点也算做充电站,设dp[i]是到第i个充电站的最短时间,那么dp[n+1]即是乌龟到达终点的最短时间. 每次到达第i个点,j:0-i-1;去找能不能用从第j个充电站直接到达 i 来更新最短时间. 注意细节处理. 1 #include<iostream> 2 #include<cstring> 3 #include<cstdio> 4 using namespace

hdu 2059(龟兔赛跑 dp)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2059 龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 11256    Accepted Submission(s): 4235 Problem Description 据说在很久很久以前,可怜的兔子经历了人生中最大的打击--赛跑

hdu 2059 龟兔赛跑(动态规划DP)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2059 龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 12442    Accepted Submission(s): 4666 Problem Description 据说在很久很久以前,可怜的兔子经历了人生中最大的打击——赛跑输

题解报告:hdu 2059 龟兔赛跑

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2059 Problem Description 据说在很久很久以前,可怜的兔子经历了人生中最大的打击--赛跑输给乌龟后,心中郁闷,发誓要报仇雪恨,于是躲进了杭州下沙某农业园卧薪尝胆潜心修炼,终于练成了绝技,能够毫不休息得以恒定的速度(VR m/s)一直跑.兔子一直想找机会好好得教训一下乌龟,以雪前耻. 最近正值HDU举办50周年校庆,社会各大名流齐聚下沙,兔子也趁此机会向乌龟发起挑战.虽然乌龟深知获胜

DP [HDU 2059] 龟兔赛跑

龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 11559    Accepted Submission(s): 4348 Problem Description 据说在很久很久以前,可怜的兔子经历了人生中最大的打击——赛跑输给乌龟后,心中郁闷,发誓要报仇雪恨,于是躲进了杭州下沙某农业园卧薪尝胆潜心修炼,终于练成了绝技,能够毫

hdu 2059 龟兔赛跑(dp)

龟兔赛跑 Problem Description 据说在很久很久以前,可怜的兔子经历了人生中最大的打击——赛跑输给乌龟后,心中郁闷,发誓要报仇雪恨,于是躲进了杭州下沙某农业园卧薪尝胆潜心修炼,终于练成了绝技,能够毫不休息得以恒定的速度(VR m/s)一直跑.兔子一直想找机会好好得教训一下乌龟,以雪前耻. 最近正值HDU举办50周年校庆,社会各大名流齐聚下沙,兔子也趁此机会向乌龟发起挑战.虽然乌龟深知获胜希望不大,不过迫于舆论压力,只能接受挑战. 比赛是设在一条笔直的道路上,长度为L米,规则很简单

hdu 2059 DP

题意: 龟兔赛跑,兔子以恒定速度跑,乌龟骑电动车,中间有若干个站点,乌龟可以选择充电或者不充,充电需要花费时间,但有电时电动车快,没电时慢,问兔子能否赢乌龟. 一开始我用了各种姿势贪心,没有过.那个时候还根本不知道什么是动态规划,这也是 hdu 11 页上少数几道算法题了 如果知道 DP 那么这道题就可以做了,对于每个站点,任务是求到达的最短时间,其最短时间可以由之前的点来更新:枚举该点的上一次充电的站点,以到达上一站点的最短时间+中间不充电花的时间,以其中最短时间作为最优解,而不用考虑本站需不

hdu 2059 龟兔赛跑 (dp)

/* 把起点和终点比作加油站,那总共有n+2个加油站了, 每次都求出从第0个到第j个加油站(j<i)分别在加满油的情况下到第i个加油站的最短时间dp[i], 最终的dp[n+1]就是最优解了. */ # include <stdio.h> # include <algorithm> # include <string.h> # define INF 999999999; using namespace std; int main() { int L,n,c,t,i