//前向星
struct node {
int nxt;
int val;
int lst;
node () {}
node (int next, int value) : nxt(next), val(value) {}
}; struct headnode {
int u;
int val;
headnode () {}
headnode (int uu, int value) : u(uu), val(value) {}
bool operator < (const headnode &a) const {
return val > a.val;
}
}; // 用于优先队列而已。val是比较的值。dist[i] int dist[maxn];
bool vis[maxn]; node edge[maxn];
int last[maxn] void Dij()
{
memset(dist, 0x3f, sizeof(dist));
memset(vis, , sizeof(vis));
priority_queue<headnode> pq;
pq.push(headnode(, ));
dist[] = ;
headnode now;
while (!pq.empty()) {
now = pq.top(); pq.pop();
if (vis[now.u]) continue;
vis[now.u] = true;
for (int i=last[now.u]; i!=-; i=edge[i].lst) {
if (dist[edge[i].nxt] > edge[i].val + dist[now.u]) {
dist[edge[i].nxt] = edge[i].val + dist[now.u];
pq.push(headnode(edge[i].nxt, dist[edge[i].nxt]));
}
}
}
}

最新文章

  1. Yii 2.x 错误处理器、异常处理器、致命错误处理器 - 类图
  2. Mac OS X系统安装盘制作
  3. map() 函数
  4. 【bzoj1084】最大子矩阵
  5. 1-5Tomcat 目录结构 和 web项目目录结构
  6. [转载] 2. JebAPI 之 jeb.api.dex
  7. 循序渐进开发WinForm项目(4)--Winform界面模块的集成使用
  8. SpriteKitCommonUse
  9. Newtonsoft.Json.JsonWriter
  10. MySQL优化技巧之五(mysql查询性能优化)
  11. boost库在工作(39)网络UDP异步服务端之九
  12. javascript脚本化文档
  13. Ubuntu+vscode打不开
  14. BugkuCTF~代码审计~WriteUp
  15. 『Island 基环树直径』
  16. unittest用例执行的顺序
  17. Spark性能调优
  18. 附录A Spring Boot应用启动器
  19. js copy数组 对象
  20. iOS获取当前路由信息

热门文章

  1. js浮点数相加、减、乘、除精确计算
  2. 解决VS Code保存时候自动格式化
  3. asp企业网站源码部分
  4. @NotNull, @NotEmpty和@NotBlank之间的区别是什么?
  5. ID基本操作(标尺,参考线,网格)5.11
  6. Win10系列:JavaScript多媒体
  7. Spring Boot 如何极简入门?
  8. Unity中物体碰撞后去掉相互之间的反弹力
  9. hdu1693
  10. [POJ2761]Feed the dogs