-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathCheckTree.cpp
69 lines (58 loc) · 1.48 KB
/
CheckTree.cpp
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include <iostream>
#include <vector>
#include <list>
#include <stack>
using namespace std;
class Graph {
long long V;
long long nEdges;
list<long long> *adj;
public:
Graph(long long V) : nEdges(0) {
this->V = V;
adj = new list<long long>[V];
}
void addEdge(long long v, long long w) {
adj[v].push_back(w);
adj[w].push_back(v);
nEdges++;
}
list<long long>& getNeighbours(long long v) { return adj[v]; }
long long getNodes() const { return V; }
long long getEdges() const { return nEdges; }
};
bool checkTree(Graph& gg);
int main() {
long long nNodes, nEdges;
cin >> nNodes >> nEdges;
Graph gg(nNodes);
for(long long i = 0; i < nEdges; i++) {
long long a, b;
cin >> a >> b;
gg.addEdge(a-1, b-1);
}
cout << (checkTree(gg) ? "YES" : "NO") << endl;
return 0;
}
bool checkTree(Graph& gg) {
// For total connection. dfs from one node should reach all n nodes.
stack<long long> ss;
vector<bool> isVisited(gg.getNodes(), false);
long long nNodes = 0;
ss.push(0);
while(!ss.empty()) {
long long curNode = ss.top();
isVisited[0] = true;
ss.pop();
nNodes++;
list<long long> curNeighbours = gg.getNeighbours(curNode);
for(auto i = curNeighbours.begin(); i != curNeighbours.end(); i++) {
if(isVisited[*i] == false) {
isVisited[*i] = true;
ss.push(*i);
}
}
}
return (nNodes == gg.getNodes()) &&
(gg.getEdges() == gg.getNodes()-1);
}