-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathbfsPersistent.cpp
More file actions
48 lines (41 loc) · 1.15 KB
/
bfsPersistent.cpp
File metadata and controls
48 lines (41 loc) · 1.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <iostream>
#include <stdlib.h>
#include <fstream>
#include <string>
#include <string.h>
#include <vector>
#include <math.h>
#include "TemporalGraph.h"
void TemporalGraph::addEdgeToIndex(int src, int dst, int startTime){
}
void TemporalGraph::removeEdgeFromIndex(int src, int dst, int startTime, int endTime){
}
int TemporalGraph::isReachable(int src, int dst, int startTime, int endTime, int c, bool fractional){
/*reset all Nodes*/
bool isReached[numNodes];
std::vector<int> queue;
for (int i = 0; i < numNodes; i++) isReached[i] = false;
int u = src;
isReached[u] = true;
queue.push_back(u);
Interval *query = new Interval(startTime, endTime);
while (queue.size() > 0){
u = queue[0];
queue.erase(queue.begin());
//for each edge from u
TemporalNode *n = nodes[u];
for (int i = 0; i < n->getNumEdges(true); i++){
TemporalEdge *e = n->getEdgeAt(i,true);
int v = e->getDestId();
Interval *x = new Interval(e->getStartTime(), e->getEndTime());
if (x->isSubInterval(query) && isReached[v] == false){
isReached[v] = true;
queue.push_back(v);
}
free(x);
}
}
free(query);
if (isReached[dst] == true) return 1;
return 0;
}