Advertisement
codisinmyvines

punkt Z pilschikov177

Jul 19th, 2020
230
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.91 KB | None | 0 0
  1. int punktZ(treeNode* root, int e)
  2. {  
  3.     bool a = true;
  4.     bool b;
  5.     int lvl = -1;
  6.     queueNode* q_top, * q_end;
  7.     treeNode* p;
  8.     treeNode* q;
  9.     treeNode* m;
  10.     p = root;
  11.     q = root;
  12.     m = root;
  13.     if (p)
  14.     {
  15.         q_top = NULL;
  16.         q_end = NULL;
  17.         push_queue(q_top, q_end, p);
  18.         do
  19.         {  
  20.             pop_queue(q_top, p);
  21.             if (m == p)
  22.             {
  23.                 lvl++;
  24.                 b = true;
  25.             }
  26.             if (p == q && p==root && a)
  27.             {
  28.                 if (p->data == e)
  29.                     return lvl;
  30.                 lvl++;
  31.                 a = false;
  32.             }
  33.             if (p->left)
  34.             {
  35.                 q = p->left;
  36.                 if (q->data == e)
  37.                     return lvl;
  38.                 push_queue(q_top, q_end, p->left);
  39.                 q = p;
  40.                 if (b)
  41.                     m = q->left;
  42.                 if (m == q->left)
  43.                     b = false;
  44.                 //a = true;
  45.             }
  46.             //q=p;
  47.             if (p->right)
  48.             {
  49.                 q = p->right;
  50.                 if (q->data == e)
  51.                     return lvl;
  52.                 q = p;
  53.                 push_queue(q_top, q_end, p->right);
  54.                 if (b)
  55.                     m = q->right;
  56.             }
  57.         } while (q_top);
  58.     }
  59.     return lvl;
  60. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement