मान लीजिए कि हमारे पास एक व्यंजक है। व्यंजक के कुछ कोष्ठक हैं; हमें यह जांचना है कि कोष्ठक संतुलित हैं या नहीं। कोष्ठकों का क्रम (), {} और [] है। मान लीजिए कि दो तार हैं। "()[(){()}]" यह मान्य है, लेकिन "{[}]" अमान्य है।
कार्य सरल है; हम ऐसा करने के लिए स्टैक का उपयोग करेंगे। समाधान पाने के लिए हमें इन चरणों का पालन करना चाहिए -
-
व्यंजक को तब तक पार करें जब तक वह समाप्त न हो जाए
-
यदि वर्तमान वर्ण ब्रैकेट खोल रहा है जैसे (, { या [, तो स्टैक में पुश करें
-
यदि वर्तमान वर्ण ब्रैकेट बंद कर रहा है जैसे ), } या ], तो स्टैक से पॉप करें, और जांचें कि क्या पॉप किया गया ब्रैकेट वर्तमान वर्ण का प्रारंभिक ब्रैकेट है, तो यह ठीक है, अन्यथा, यह संतुलित नहीं है।
-
-
स्ट्रिंग समाप्त होने के बाद, यदि स्टैक में कुछ शुरुआती ब्रैकेट बचे हैं, तो स्ट्रिंग संतुलित नहीं है।
उदाहरण
#include <iostream> #include <stack> using namespace std; bool isBalancedExp(string exp) { stack<char> stk; char x; for (int i=0; i<exp.length(); i++) { if (exp[i]=='('||exp[i]=='['||exp[i]=='{') { stk.push(exp[i]); continue; } if (stk.empty()) return false; switch (exp[i]) { case ')': x = stk.top(); stk.pop(); if (x=='{' || x=='[') return false; break; case '}': x = stk.top(); stk.pop(); if (x=='(' || x=='[') return false; break; case ']': x = stk.top(); stk.pop(); if (x =='(' || x == '{') return false; break; } } return (stk.empty()); } int main() { string expresion = "()[(){()}]"; if (isBalancedExp(expresion)) cout << "This is Balanced Expression"; else cout << "This is Not Balanced Expression"; }
इनपुट
"()[(){()}]"
आउटपुट
This is Balanced Expression