hdu 1548 A strange lift
2015-06-08 13:13
405 查看
#include<stdio.h> #include<string.h> #include<algorithm> using namespace std; const int inf=10024; int mp[200+5][200+5],dist[200+5],n,vis[200+5]; void Dijkstra(int v0) { int i,j,k,u,minx; for(i=1;i<=n;i++) { dist[i]=mp[v0][i]; vis[i]=0; } vis[v0]=1; dist[v0]=0; for(i=0;i<n-1;i++) { minx=inf,u=v0; for(j=1;j<=n;j++) { if(!vis[j]&&dist[j]<minx) { minx=dist[j]; u=j; } } vis[u]=1; for(k=1;k<=n;k++) { if(!vis[k]&&mp[u][k]<inf) dist[k]=min(dist[k],dist[u]+mp[u][k]); } } } int main() { int a,b,k,i,j,x,y; while(~scanf("%d",&n)&&n) { scanf("%d%d",&a,&b); memset(mp,0,sizeof(mp)); for(i=1; i<=n; i++) { scanf("%d",&x); if(i-x>=1) mp[i][i-x]=1; if(x+i<=n) mp[i][x+i]=1; } for(i=1;i<=n;i++) { for(j=1;j<=n;j++) { if(i==j) mp[i][j]=0; else if(mp[i][j]==0) mp[i][j]=inf; } } Dijkstra(a); if(a==b) printf("0\n"); else if(dist[b]<inf) printf("%d\n",dist[b]); else printf("-1\n"); } return 0; }
相关文章推荐
- AngularJS(二)——使用AngularJS自定义service
- 【剑指offer】 面试题4: 替换空格
- android 使用 shape
- apache出现open_basedir错误
- 参数化查询---解决sql漏洞注入
- 2015/6/8 站立会议
- HBase物理结构理解以及与ORACLE特性分析
- mybatis批量插入、批量删除
- mysql 分表的实现方法
- 用例图
- 关于在asp.net中的调试
- 2015/6/8 站立会议以及索引卡更新
- 路线
- 软文创意18招之一:挖历史
- EntityFramework Model有外键时,Json提示循环引用 解决方法
- Xamarin破解后出现闪退处理
- 读书计划
- Android中垃圾回收日志信息
- Android自动化测试之MonkeyRunner-startActivity之component(十四)
- Android自动化测试之MonkeyRunner-之getProperty、getSystemProperty(十三)