13af6ab5fSopenharmony_ci/*
23af6ab5fSopenharmony_ci * Copyright (c) 2022-2024 Huawei Device Co., Ltd.
33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License.
53af6ab5fSopenharmony_ci * You may obtain a copy of the License at
63af6ab5fSopenharmony_ci *
73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
83af6ab5fSopenharmony_ci *
93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and
133af6ab5fSopenharmony_ci * limitations under the License.
143af6ab5fSopenharmony_ci */
153af6ab5fSopenharmony_ci
163af6ab5fSopenharmony_ciclass TreeNode {
173af6ab5fSopenharmony_ci  private left: TreeNode | null;
183af6ab5fSopenharmony_ci  private right: TreeNode | null;
193af6ab5fSopenharmony_ci  private item: int;
203af6ab5fSopenharmony_ci
213af6ab5fSopenharmony_ci  constructor(left: TreeNode | null, right: TreeNode | null, item: int) {
223af6ab5fSopenharmony_ci    this.left = left;
233af6ab5fSopenharmony_ci    this.right = right;
243af6ab5fSopenharmony_ci    this.item = item;
253af6ab5fSopenharmony_ci  }
263af6ab5fSopenharmony_ci
273af6ab5fSopenharmony_ci  public itemCheck(): int {
283af6ab5fSopenharmony_ci    if (this.left == null)
293af6ab5fSopenharmony_ci      return this.item;
303af6ab5fSopenharmony_ci    else
313af6ab5fSopenharmony_ci      return this.item + this.left!.itemCheck() - this.right!.itemCheck();
323af6ab5fSopenharmony_ci  }
333af6ab5fSopenharmony_ci}
343af6ab5fSopenharmony_ci
353af6ab5fSopenharmony_ciexport class AccessBinaryTrees {
363af6ab5fSopenharmony_ci  static readonly startDepth = 4;
373af6ab5fSopenharmony_ci  static readonly endDepth = 7;
383af6ab5fSopenharmony_ci  static readonly expected = -4;
393af6ab5fSopenharmony_ci
403af6ab5fSopenharmony_ci  static bottomUpTree(item: int, depth: int): TreeNode {
413af6ab5fSopenharmony_ci   if (depth > 0) {
423af6ab5fSopenharmony_ci     return new TreeNode(
433af6ab5fSopenharmony_ci       AccessBinaryTrees.bottomUpTree(2*item - 1, depth-1),
443af6ab5fSopenharmony_ci       AccessBinaryTrees.bottomUpTree(2*item, depth-1),
453af6ab5fSopenharmony_ci       item
463af6ab5fSopenharmony_ci     );
473af6ab5fSopenharmony_ci   }
483af6ab5fSopenharmony_ci   return new TreeNode(null, null, item);
493af6ab5fSopenharmony_ci  }
503af6ab5fSopenharmony_ci
513af6ab5fSopenharmony_ci  public run(): void {
523af6ab5fSopenharmony_ci    let ret: int = 0;
533af6ab5fSopenharmony_ci
543af6ab5fSopenharmony_ci    for (let n: int = AccessBinaryTrees.startDepth; n <= AccessBinaryTrees.endDepth; n++) {
553af6ab5fSopenharmony_ci      let minDepth: int = AccessBinaryTrees.startDepth;
563af6ab5fSopenharmony_ci      let maxDepth: int = max(minDepth + 2, n);
573af6ab5fSopenharmony_ci      let stretchDepth: int = maxDepth + 1;
583af6ab5fSopenharmony_ci      let check: int = AccessBinaryTrees.bottomUpTree(0, stretchDepth).itemCheck();
593af6ab5fSopenharmony_ci
603af6ab5fSopenharmony_ci      let longLivedTree = AccessBinaryTrees.bottomUpTree(0, maxDepth);
613af6ab5fSopenharmony_ci
623af6ab5fSopenharmony_ci      for (let depth = minDepth; depth <= maxDepth; depth += 2) {
633af6ab5fSopenharmony_ci        let iterations: int = 1 << (maxDepth - depth + minDepth);
643af6ab5fSopenharmony_ci
653af6ab5fSopenharmony_ci        check = 0;
663af6ab5fSopenharmony_ci        for (let i: int = 1; i <= iterations; i++) {
673af6ab5fSopenharmony_ci          check += AccessBinaryTrees.bottomUpTree(i, depth).itemCheck();
683af6ab5fSopenharmony_ci          check += AccessBinaryTrees.bottomUpTree(-i, depth).itemCheck();
693af6ab5fSopenharmony_ci        }
703af6ab5fSopenharmony_ci      }
713af6ab5fSopenharmony_ci
723af6ab5fSopenharmony_ci      ret += longLivedTree.itemCheck();
733af6ab5fSopenharmony_ci    }
743af6ab5fSopenharmony_ci
753af6ab5fSopenharmony_ci    assert ret == AccessBinaryTrees.expected: "Incorrect result"
763af6ab5fSopenharmony_ci  }
773af6ab5fSopenharmony_ci}
783af6ab5fSopenharmony_ci
793af6ab5fSopenharmony_cifunction main(): void {
803af6ab5fSopenharmony_ci  let a = new AccessBinaryTrees;
813af6ab5fSopenharmony_ci  a.run();
823af6ab5fSopenharmony_ci}
83