aboutsummaryrefslogtreecommitdiff
path: root/codechef/DenseBracketSequence/main.cpp
diff options
context:
space:
mode:
authoromagdy7 <omar.professional8777@gmail.com>2022-06-29 15:57:29 +0200
committeromagdy7 <omar.professional8777@gmail.com>2022-06-29 15:57:29 +0200
commit1b8f7c9d4eb8b767d32dbbbfd96662b73c037627 (patch)
tree7f984139dcca441d7ab582e0c67daa125e400a14 /codechef/DenseBracketSequence/main.cpp
parent7860cb994fbf6af63865eb6dc9045bbc8abd61a4 (diff)
downloadcompetitive-programming-1b8f7c9d4eb8b767d32dbbbfd96662b73c037627.tar.xz
competitive-programming-1b8f7c9d4eb8b767d32dbbbfd96662b73c037627.zip
Solved some problem from codechef and codeforces
Diffstat (limited to 'codechef/DenseBracketSequence/main.cpp')
-rw-r--r--codechef/DenseBracketSequence/main.cpp33
1 files changed, 33 insertions, 0 deletions
diff --git a/codechef/DenseBracketSequence/main.cpp b/codechef/DenseBracketSequence/main.cpp
new file mode 100644
index 0000000..6785a12
--- /dev/null
+++ b/codechef/DenseBracketSequence/main.cpp
@@ -0,0 +1,33 @@
+#include <bits/stdc++.h>
+
+using namespace std;
+
+int main() {
+ ios_base::sync_with_stdio(false);
+ cin.tie(NULL);
+ int tt;
+ cin >> tt;
+ while (tt--) {
+ int n;
+ cin >> n;
+ string s;
+ cin >> s;
+ int count = 0;
+ stack<char> st;
+ st.push(s[0]);
+ for(int i = 1; i < n; i++) {
+ if(s[i] == '(') {
+ st.push('(');
+ }
+ if(s[i] == ')') {
+ if(st.top() == '(' && !st.empty()){
+ st.pop();
+ count++;
+ }
+ }
+ }
+ cout << count << endl;
+ }
+}
+
+