http://codility.com/demo/take-sample-test/hydrogenium2013

用Dijkstra求最短路径,同时和D[i]比较判断是不是能到。用了优先队列优化,复杂度是(m+n)*log(n)。同时,写Dijkstra的时候一般要用dist数组,这里只拿它做访问标示。中间有个坑就是两个点之间可以多条路径,fail了半天。

#include <queue>
#include <functional> #define pp pair<int,int>
int solution(const vector<int> &A, const vector<int> &B, const vector<int> &C, const vector<int> &D) {
// write your code in C++98
int N = A.size();
int M = D.size();
vector<vector<int> > graph;
graph.resize(M);
for (int i = 0; i < M; i++) {
graph[i].resize(M, -1);
}
for (int i = 0; i < N; i++) {
graph[A[i]][B[i]] = (graph[A[i]][B[i]] == -1 ? C[i] : min(graph[A[i]][B[i]], C[i]));
graph[B[i]][A[i]] = (graph[B[i]][A[i]] == -1 ? C[i] : min(graph[B[i]][A[i]], C[i]));
} vector<int> dist(M, -1);
priority_queue<pp, vector<pp>, greater<pp> > que;
que.push(make_pair(0, 0));
while (!que.empty()) {
pp p = que.top();
que.pop();
if (dist[p.second] == -1) {
dist[p.second] = p.first;
}
else {
continue;
}
if (p.first <= D[p.second]) return p.first;
for (int i = 0; i < graph[p.second].size(); i++) {
if (graph[p.second][i] != -1) {
que.push(make_pair(graph[p.second][i] + p.first, i));
}
}
}
return -1;
}

  

最新文章

  1. 【Android Studio】android Internal HTTP server disabled 解决
  2. 【转载】制作一个超精简的WIN7.gho
  3. Gym 100917J---dir -C(RMQ--ST)
  4. BizTalk动手实验(十)业务活动监控(BAM)演示
  5. 用PHP实现定时器功能
  6. LightOJ 1248 Dice (III) 概率
  7. Applescript 带参数调用某个App的方法
  8. ABBYY PDF Transformer+从文件选项中创建PDF文档的教程
  9. LESS快速入门
  10. 我的 MarkDown 学习笔记
  11. SnackbarUtils:一行代码搞定Snackbar
  12. Spring MVC CORS 跨域
  13. Windows Server 2016-命令行批量导出AD用户列表信息
  14. js入门关于函数
  15. Redis深入学习笔记(一)Redis启动数据加载流程
  16. 洛谷P3808 【模板】AC自动机(简单版)
  17. eclipse中建geoserver源码
  18. 使用Vmware安装linux且配置终端可以连接虚拟机总结
  19. bzoj3326: [Scoi2013]数数
  20. luogu P2709 小B的询问

热门文章

  1. 如何用java实现使用电子邮件控制你的电脑
  2. 查看源代码查找获取sd卡剩余容量的代码
  3. openlayers wfs获取要素
  4. ODBC连接MySQL出现&quot;E_FAIL&quot;错误
  5. html-----018----HTML Web Server/HTML URL 字符编码
  6. C#基础总复习01
  7. Flexbox介绍
  8. LevelDb原理剖析
  9. 第9条:覆盖equals时总要覆盖hashCode
  10. leetcode Permutations II 无重全排列