PRoblem Description 據說在很久很久以前,可憐的兔子經歷了人生中最大的打擊——賽跑輸給烏龜后,心中郁悶,發誓要報仇雪恨,于是躲進了杭州下沙某農業園臥薪嘗膽潛心修煉,終于練成了絕技,能夠毫不休息得以恒定的速度(VR m/s)一直跑。兔子一直想找機會好好得教訓一下烏龜,以雪前恥。 最近正值HDU舉辦50周年校慶,社會各大名流齊聚下沙,兔子也趁此機會向烏龜發起挑戰。雖然烏龜深知獲勝希望不大,不過迫于輿論壓力,只能接受挑戰。 比賽是設在一條筆直的道路上,長度為L米,規則很簡單,誰先到達終點誰就算獲勝。 無奈烏龜自從上次獲勝以后,成了名龜,被一些八卦雜志稱為“動物界的劉翔”,廣告不斷,手頭也有了不少積蓄。為了能夠再贏兔子,烏龜不惜花下血本買了最先進的武器——“”小飛鴿”牌電動車。這輛車在有電的情況下能夠以VT1 m/s的速度“飛馳”,可惜電池容量有限,每次充滿電最多只能行駛C米的距離,以后就只能用腳來蹬了,烏龜用腳蹬時的速度為VT2 m/s。更過分的是,烏龜竟然在跑道上修建了很多很多(N個)的供電站,供自己給電動車充電。其中,每次充電需要花費T秒鐘的時間。當然,烏龜經過一個充電站的時候可以選擇去或不去充電。 比賽馬上開始了,兔子和帶著充滿電的電動車的烏龜并列站在起跑線上。你的任務就是寫個程序,判斷烏龜用最佳的方案進軍時,能不能贏了一直以恒定速度奔跑的兔子。
Input 本題目包含多組測試,請處理到文件結束。每個測試包括四行: 第一行是一個整數L代表跑道的總長度 第二行包含三個整數N,C,T,分別表示充電站的個數,電動車沖滿電以后能行駛的距離以及每次充電所需要的時間 第三行也是三個整數VR,VT1,VT2,分別表示兔子跑步的速度,烏龜開電動車的速度,烏龜腳蹬電動車的速度 第四行包含了N(N<=100)個整數p1,p2…pn,分別表示各個充電站離跑道起點的距離,其中0
import java.util.*;class Main{ static int t,l,n,c,vr,vt1,vt2; static double []d; static double time; public static void main(String args[]){ Scanner sc= new Scanner(System.in); while(sc.hasNext()) { l=sc.nextInt(); n=sc.nextInt(); c=sc.nextInt(); t=sc.nextInt(); vr=sc.nextInt(); vt1=sc.nextInt(); vt2=sc.nextInt(); int []p=new int [n+2]; for(int i=1;i<=n;i++){ p[i]=sc.nextInt(); } p[0]=0;p[n+1]=l; d=new double[n+2]; for(int i=0;i<n+2;i++){ d[i]=0; } for(int i=1;i<n+2;i++){ double min=Integer.MAX_VALUE; int dis; for(int j=0;j<i;j++){ dis =p[i]-p[j]; time = dis >c?(1.0*c/vt1+(dis-c)*1.0/vt2):(1.0*dis/vt1);//時間 if(j!=0) time =time+t; if(time + d[j]< min)// min = time + d[j]; } d[i]=min; } String s = d[n+1]<1.0*l/vr?"What a pity rabbit!":"Good job,rabbit!"; System.out.println(s); } }}新聞熱點
疑難解答