-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathRailwayGraph.h
More file actions
41 lines (27 loc) · 1.04 KB
/
RailwayGraph.h
File metadata and controls
41 lines (27 loc) · 1.04 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
#ifndef RAILWAY_GRAPH_H_
#define RAILWAY_GRAPH_H_
#include "Utils.h"
#include "RouteSectionInfo.h"
#include "DataStructure/Graph.h"
#include "DataStructure/List.h"
#include "DataStructure/DisjointSet.h"
namespace trainsys {
class RailwayGraph {
private:
using GraphType = adjListGraph<RouteSectionInfo *>;
GraphType routeGraph;
DisjointSet stationSet;
seqList<RouteSectionInfo *> routeSectionPool;
public:
RailwayGraph();
~RailwayGraph();
void addRoute(StationID departureStationID, StationID arrivalStationID, int duration, int price,
TrainID trainID);
bool checkStationAccessibility(StationID departureStationID, StationID arrivalStationID);
void displayRoute(StationID departureStationID, StationID arrivalStationID);
void shortestPath(StationID departureStationID, StationID arrivalStationID, int type);
private:
void routeDfs(int curIdx, int arrivalIdx, seqList<StationID> &prevStations, bool *visited);
};
}
#endif