-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBOJ10799.cpp
61 lines (52 loc) · 1.06 KB
/
BOJ10799.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
#define _CRT_SECURE_NO_WARNINGS
#include <bits/stdc++.h>
using namespace std;
string input;
vector<int> laser;
stack<int> s;
int main()
{
cin >> input;
int ans = 0;
for (int i = 0; i < input.size(); ++i) {
if (input[i] == '(') {
s.push(i);
}
else {
if (s.top() == i - 1) {
laser.push_back(i - 1);
}
else {
int t = 1;
for (int j = 0; j < laser.size(); ++j) {
if (s.top() < laser[j] && laser[j] < i) {
++t;
}
}
ans += t;
}
s.pop();
}
}
printf("%d", ans);
return 0;
}
/*
//kks227's solution.
#include <cstdio>
using namespace std;
int main(){
char c, prev = '.';
int sum = 0, cnt = -1;
while((c=getchar())>'\n'){
if(c=='(') cnt++;
else{
if(prev=='(') sum += cnt;
else sum++;
cnt--;
}
prev = c;
}
printf("%d\n", sum);
}
*/