Advertisement
codisinmyvines

punkt I pilschikov 17.7

Jul 19th, 2020
220
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.86 KB | None | 0 0
  1. int punktI(treeNode* root, int k)
  2. {  
  3.     int lvl{ 0 };
  4.     int kol{ 0 };
  5.     bool a, b;
  6.     queueNode* q_top, * q_end;
  7.     treeNode* p;
  8.     treeNode* m;
  9.     treeNode* q;
  10.     p = root;
  11.     m = root;
  12.     q = 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.                 b = true;
  24.                 lvl++;
  25.             }
  26.             if (lvl > k)
  27.                 break;
  28.             if (k == 0 && p == root)
  29.                 return 1;
  30.             if (p->left)
  31.             {
  32.                 push_queue(q_top, q_end, p->left);
  33.                 q = p->left;
  34.                 if (q == p->left && k == lvl)
  35.                     kol++;
  36.                 q = p;
  37.                 if (b)
  38.                     m = q->left;
  39.                 if (m == q->left)
  40.                     b = false;
  41.             }
  42.             if (p->right)
  43.             {  
  44.                 push_queue(q_top, q_end, p->right);
  45.                 q = p->right;
  46.                 if (q == p->right && k == lvl)
  47.                     kol++;
  48.                 q = p;
  49.                 if (b)
  50.                     m = q->right;
  51.             }
  52.         } while (q_top);
  53.     }
  54.     return kol;
  55. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement