Advertisement
aimon1337

Untitled

Mar 20th, 2022
783
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.59 KB | None | 0 0
  1. #include <iostream>
  2. #include <string>
  3. #include <queue>
  4. using std::string;
  5.  
  6. struct stack
  7. {
  8.     std::queue<char> q1, q2;
  9.     int curr_size;
  10.     stack()
  11.     {
  12.         curr_size = 0;
  13.     }
  14.     void push(char x)
  15.     {
  16.         q1.push(x);
  17.         curr_size++;
  18.     }
  19.     void pop()
  20.     {
  21.         if (q1.empty())
  22.             return;
  23.         while (q1.size() != 1)
  24.         {
  25.             q2.push(q1.front());
  26.             q1.pop();
  27.         }
  28.         q1.pop();
  29.         curr_size--;
  30.         std::queue<char> q = q1;
  31.         q1 = q2;
  32.         q2 = q;
  33.     }
  34.     int top()
  35.     {
  36.         if (q1.empty())
  37.             return -1;
  38.  
  39.         while (q1.size() != 1) {
  40.             q2.push(q1.front());
  41.             q1.pop();
  42.         }
  43.         char temp = q1.front();
  44.         q1.pop();
  45.         q2.push(temp);
  46.         std::queue<char> q;
  47.         q = q1;
  48.         q1 = q2;
  49.         q2 = q;
  50.         return temp;
  51.     }
  52.     int size()
  53.     {
  54.         return curr_size;
  55.     }
  56.     bool empty()
  57.     {
  58.         return curr_size == 0;
  59.     }
  60. };
  61.  
  62. int anterior(char s)
  63. {
  64.     if (s == '(' || s == ')')
  65.         return 1;
  66.     else if (s == '[' || s == ']')
  67.         return 2;
  68.     else if (s == '{' || s == '}')
  69.         return 3;
  70. }
  71. bool verificare(std::string s,stack Stack)
  72. {
  73.  
  74.     for (int i = 0; i < s.size(); i++)
  75.     {
  76.  
  77.  
  78.         if (s[i] == '{' || s[i] == '[' || s[i] == '(')
  79.         {
  80.             Stack.push(s[i]);
  81.             if (anterior(Stack.top()) <= anterior(s[i])) return false;
  82.  
  83.  
  84.         }
  85.         else if (s[i] == '}' || s[i] == ']' || s[i] == ')')
  86.         {
  87.             if (anterior(s[i]) != anterior(Stack.top())) return false;
  88.             Stack.pop();
  89.  
  90.         }
  91.     }
  92.     if (Stack.size() != 0)
  93.         return false;
  94.  
  95.     return true;
  96. }
  97. int main()
  98. {
  99.     string s;
  100.     std::cin >> s;
  101.     stack Stack;
  102.     if (verificare(s,Stack))
  103.     {
  104.         std::cout << "Expresia este valida.\n";
  105.     }
  106.     else
  107.     {
  108.         std::cout << "Expresia nu este valida.\n";
  109.     }
  110.     return 0;
  111. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement