Online Judge | Problem Set | Authors | Online Contests | User | ||||||
---|---|---|---|---|---|---|---|---|---|---|
Web Board Home Page F.A.Qs Statistical Charts | Current Contest Past Contests Scheduled Contests Award Contest |
Re:有谁帮我看一下?WAIn Reply To:有谁帮我看一下?WA Posted by:BJ051155 at 2007-07-23 17:04:42 > #include <iostream> > using namespace std; > int stackx[20000],stacky[20000]; > int cost[200][200]; > > int main(int argc, char* argv[]) > { > short n,m,k; > int a[105],b[105],c[105]; > while(scanf("%d%d%d",&n,&m,&k)) > { > if(n==0&&m==0&&k==0) > break; > for(int i=0;i<k;i++) > scanf("%d%d%d",&a[i],&b[i],&c[i]); > for(i=0;i<200;i++) > for(int j=0;j<200;j++) > cost[i][j]=0; > int qh=0,qe=1; > stackx[qh]=0; > stacky[qh]=0; > while(qh<qe) > { > for(i=0;i<k;i++) > { > int x=stackx[qh]+a[i]; > int y=stacky[qh]+b[i]; > if(x>=0&&y>=0&&x<=n&&y<=m&&(cost[x][y]==0||cost[stackx[qh]][stacky[qh]]+c[i]<cost[x][y])) > { > stackx[qe]=x; > stacky[qe]=y; > qe++; > cost[x][y]=cost[stackx[qh]][stacky[qh]]+c[i]; > } > } > qh++; > } > if(cost[n][m]==0) > printf("-1\n"); > else > printf("%d\n",cost[n][m]); > } > return 0; > } Followed by: Post your reply here: |
All Rights Reserved 2003-2013 Ying Fuchen,Xu Pengcheng,Xie Di
Any problem, Please Contact Administrator