用广搜实现的spfa,如果是用一般的最短路,会发现构图很麻烦,因为它不是路径带权值,而是自身带权值。写起来只要注意,在点出队列的生活将其标记为0,在要压入队列的时候,判断其标记是否为0,为0表示队列中木有这个点,则压入........还有一点,其实这个点即使在队列里面,只要是这个点有比当前的路径短的,就需要更新这个点的最短路,当然,这个点已经在队列里面了,我们就只需要更新它,而不需要把它加入队列......

void dj()
{
queue<node>q;
for(ss i=0;i<=n;i++)
for(ss j=0;j<=n;j++)
dis[i][j]=maxx;
dis[n][n]=a[n][n];
memset(vist,0,sizeof(vist));
vist[n][n]=1;
node tmp;
tmp.x=n;
tmp.y=n;
q.push(tmp);
while(!q.empty())
{
node tmp1=q.front();
q.pop();
vist[tmp1.x][tmp1.y]=0;
for(ss i=0;i<4;i++)
{
ss xx=tmp1.x+t[i][0];
ss yy=tmp1.y+t[i][1];
if(xx>=1&&xx<=n&&yy>=1&&yy<=n&&dis[xx][yy]>dis[tmp1.x][tmp1.y]+a[xx][yy])
{
dis[xx][yy]=dis[tmp1.x][tmp1.y]+a[xx][yy];
if(!vist[xx][yy])
{
node tmp2;
tmp2.x=xx;
tmp2.y=yy;
q.push(tmp2);
vist[xx][yy]=1;
}
}
}
}
}

最新文章

  1. Deepin 15.3 编译同步SudaMod 2.0
  2. Memcached,你懂的
  3. StackOverflow Update: 560M Pageviews A Month, 25 Servers, And It&#39;s All About Performance
  4. vue2.0 transition -- demo实践填坑
  5. 又一个提示框思密达,腾讯UED
  6. 如何让你的Apache支持include文件解析和支持shtml的相关配置
  7. appserver配置虚拟主机
  8. Win7系统下利用U盘安装Ubuntu14.04麒麟版
  9. Unity3D脚本中文系列教程(三)
  10. 【完结】利用 Composer 完善自己的 PHP 框架(三)——Redis 缓存
  11. 14、AppWidget及Launcher
  12. 关于jQuery中的ajax的方法介绍
  13. selenium + firefox/chrome/phantomjs登陆之模拟点击
  14. js和android及ios交互
  15. Apache设置404页面
  16. java集合(4)- java中HashSet详解
  17. WAF指纹探测及识别技术
  18. ORACLE数据库管理员的职责
  19. CentOS 7中允许远程连接mariadb数据库
  20. Android Studio连接天天模拟器

热门文章

  1. [Todo] Nodejs学习及Spider实验(包括php入门学习、React入门学习)
  2. DataBindings的用法
  3. JavaScript 你不知道的事 -- 关于函数
  4. IE6支持min-width、max-width CSS样式属性
  5. Node.js:模块系统、函数
  6. 后缀树(Suffix Trie)子串匹配结构
  7. POJ2528:Mayor&#39;s posters(线段树区间更新+离散化)
  8. mac远程桌面Microsoft Remote Desktop for Mac的安装与使用
  9. (LeetCode 49)Anagrams
  10. photoshop cs6 Mac版本