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