-
Notifications
You must be signed in to change notification settings - Fork 25
/
Nesting.cpp
55 lines (49 loc) · 1.21 KB
/
Nesting.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
// https://app.codility.com/programmers/lessons/7-stacks_and_queues/nesting/
//
// Task Score: 100%
// Correctness: 100%
// Performance: 100%
// Detected time complexity: O(N)
//
#include <string>
#include <stack>
using namespace std;
int solution(string &S) {
int N = S.length();
// Quick check for empty string
if ( N == 0) {
return 1;
}
// Any nested string is a pair, so odd length strings are improperly nested
if ( N%2 ) {
return 0;
}
// Go through the string:
// * Push if '('
// * Pop if ')' and check if '(' returned - return 0 if not
// * When done with loop, stack should be empty, return 0 if not
// This is O(N)
stack<char> nest;
char c;
for (int i=0; i<N; i++) {
switch (S[i]) {
case '(':
nest.push(S[i]);
break;
case ')':
c = nest.top();
nest.pop();
if ( c != '(') {
return 0;
}
break;
default: break;
}
}
// Some elements were left hanging!
if (nest.size() > 0 ) {
return 0;
}
// No errors, so good!
return 1;
}