一道單源最短路徑,兩點間的距離除以速度作為邊上的權
鬱悶的是居然TLE了,找了一個多小時,發現只要加一句system("pause")就可以了。。。不過WA了(其實應該數組開小了,200個stop加上家和學習,開到201不夠。。。又是細節問題)不過為什麼不直接報RE,加上那句才報呢。。。
後來想了下,是算權的時候錯了,當起點或終點的y值與網站一樣時,應該按步行的速度算,但修改後還是WA了。。。
後來參照別人的在讀資料時就算權,過了,唉。。。
代碼:
#include<iostream><br />#include<cstdio><br />#include<cmath><br />#include<algorithm><br />const double inf =9999999.9;<br />double x[401],y[401],g[401][401],dis[401];<br />int u[201],cnt;<br />int main()<br />{<br />int i,j,k,flag;<br />double a,b,min,temp;<br />scanf("%lf%lf%lf%lf",&x[1],&y[1],&x[2],&y[2]);<br />cnt=3;<br />flag=0;<br />memset(g,0,sizeof(g));<br />while(scanf("%lf%lf",&a,&b)!=EOF)<br />{<br />if(a==-1&&b==-1)<br />{<br />flag=0;<br />continue;<br />}<br />if(a==-2&&b==-2)<br />break;<br />x[cnt]=a;<br />y[cnt]=b;<br />if(flag)//flag判斷是否為subway的起點<br />{<br />temp=(sqrt((x[cnt]-x[cnt-1])*(x[cnt]-x[cnt-1])+(y[cnt]-y[cnt-1])*(y[cnt]-y[cnt-1])))/40000.0;<br />g[cnt][cnt-1]=g[cnt-1][cnt]=temp;<br />}<br />cnt++;<br />flag=1;<br />}<br />for(i=1;i<cnt;i++)<br />for(j=1;j<cnt;j++)<br />{<br />if(i!=j&&g[i][j]==0.0)<br />g[i][j]=g[j][i]=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]))/10000.0;<br />}<br />u[1]=1;<br />for(i=1;i<cnt;i++)<br />dis[i]=g[1][i];<br />for(i=1;i<cnt;i++)<br />{<br />min=inf;<br />for(j=1;j<cnt;j++)<br />{<br />if(!u[j]&&dis[j]<min)<br />{<br />min=dis[j];<br />k=j;<br />}<br />}<br />u[k]=1;<br />for(j=1;j<cnt;j++)<br />{<br />if(dis[j]>dis[k]+g[k][j])<br />dis[j]=dis[k]+g[k][j];<br />}<br />}<br />printf("%.0lf/n",60.0*dis[2]);<br />system("pause");<br />return 0;<br />}