无权最短路径 广度优先搜索
2016-07-11 00:00
369 查看
《数据结构与算法分析——C语言描述》 第九章
O(V^2)
O(E+V),书上的代码有点小错,从队列里弹出一个点没有判断这个点是否访问过。应该加上判断,已经访问过就不用再处理这个点。例如多个点同时邻接到一个点的时候,这个点就会多次加入到一个队列中。所以从队列里弹出来的点有可能是访问过的。
void unweighed(Vertex srcVex, Graph g) {
Vertex v, w;
int *known = (int *)malloc(sizeof(int)*vexNum);
if (known == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
known[i] = 0;
int *dv = (int *)malloc(sizeof(int)*vexNum);
if (dv == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
dv[i] = INT_MAX;
dv[srcVex] = 0;
int *pv = (int *)malloc(sizeof(int)*vexNum);
if (pv == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
pv[i] = srcVex;
std::queue<int> q;
q.push(srcVex);
while (!q.empty()) {
v = q.front();
q.pop();
if (known[v] == 0) {
known[v] = 1;
EdgeNodePtr p = getEdgeNodePtr(v, g);
while (p) {
w = getVex(p);
dv[w] = dv[v] + 1;
pv[w] = v;
q.push(w);
p = advance(p);
}
}
}
for (int i = 0; i < vexNum; i++) {
int j = i;
if (known[j] == 1) {
std::stack<int> s;
if (j != srcVex)
s.push(j);
while (pv[j] != srcVex) {
s.push(pv[j]);
j = pv[j];
}
s.push(pv[j]);
while (!s.empty()) {
printf("%s ", nameRecord[s.top()]);
s.pop();
}
printf("\n");
}
else {
printf("cannot reach\n");
}
}
}
O(V^2)
void unweighed(Vertex srcVex,Graph g) { int currDist; Vertex v, w; int *known = (int *)malloc(sizeof(int)*vexNum); if (known == NULL) Error("OUT OF MEMORY"); for (int i = 0; i < vexNum; i++) known[i] = 0; int *dv = (int *)malloc(sizeof(int)*vexNum); if (dv == NULL) Error("OUT OF MEMORY"); for (int i = 0; i < vexNum; i++) dv[i] = INT_MAX; dv[srcVex] = 0; int *pv = (int *)malloc(sizeof(int)*vexNum); if (pv == NULL) Error("OUT OF MEMORY"); for (int i = 0; i < vexNum; i++) pv[i] = srcVex; for (currDist = 0; currDist < vexNum; currDist++) { for (v = 0; v < vexNum; v++) { if (!known[v] && dv[v] == currDist) { known[v] = 1; EdgeNodePtr p = getEdgeNodePtr(v, g); while (p) { w = getVex(p); if (dv[w] == INT_MAX) { dv[w] = currDist + 1; pv[w] = v; } p = advance(p); } } } } for (int i = 0; i < vexNum; i++) { int j = i; if (known[j] == 1) { std::stack<int> s; if (j != srcVex) s.push(j); while (pv[j] != srcVex) { s.push(pv[j]); j = pv[j]; } s.push(pv[j]); while (!s.empty()) { printf("%d ", s.top()); s.pop(); } printf("\n"); } else { printf("cannot reach\n"); } } }
O(E+V),书上的代码有点小错,从队列里弹出一个点没有判断这个点是否访问过。应该加上判断,已经访问过就不用再处理这个点。例如多个点同时邻接到一个点的时候,这个点就会多次加入到一个队列中。所以从队列里弹出来的点有可能是访问过的。
void unweighed(Vertex srcVex, Graph g) {
Vertex v, w;
int *known = (int *)malloc(sizeof(int)*vexNum);
if (known == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
known[i] = 0;
int *dv = (int *)malloc(sizeof(int)*vexNum);
if (dv == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
dv[i] = INT_MAX;
dv[srcVex] = 0;
int *pv = (int *)malloc(sizeof(int)*vexNum);
if (pv == NULL)
Error("OUT OF MEMORY");
for (int i = 0; i < vexNum; i++)
pv[i] = srcVex;
std::queue<int> q;
q.push(srcVex);
while (!q.empty()) {
v = q.front();
q.pop();
if (known[v] == 0) {
known[v] = 1;
EdgeNodePtr p = getEdgeNodePtr(v, g);
while (p) {
w = getVex(p);
dv[w] = dv[v] + 1;
pv[w] = v;
q.push(w);
p = advance(p);
}
}
}
for (int i = 0; i < vexNum; i++) {
int j = i;
if (known[j] == 1) {
std::stack<int> s;
if (j != srcVex)
s.push(j);
while (pv[j] != srcVex) {
s.push(pv[j]);
j = pv[j];
}
s.push(pv[j]);
while (!s.empty()) {
printf("%s ", nameRecord[s.top()]);
s.pop();
}
printf("\n");
}
else {
printf("cannot reach\n");
}
}
}
相关文章推荐
- 【SSH系列】spring中为什么要使用IOC
- Spring-FactoryBean的使用
- Zookeeper Api(java)入门与应用(转)
- mysql 实现类似rownum伪列
- System.Text.StringBuilder 类
- 关于telnet
- 这些对比工具你会用哪个
- 作为程序员一定要会这些软件
- 解压,中文目录问题
- angularjs下拉选择框数据绑定问题
- js分享
- window.onblur 和 window.onfocus
- 用面向对象的思路建设计数据库
- 分享几个前端干货,面试经常提
- 14: PYCURL ERROR 6 - "Couldn't resolve host 'mirro
- 3 - javascript原型和闭包( prototype原型)
- 4 - javascript原型和闭包(隐式原型)
- 外键(FOREIGN KEY)
- AppCan4.0:开发者要做有价值的APP
- Angular2学习笔记之Router篇