CSC300: Forward recursion, nullable argument [4/11] Previous pageContentsNext page

11
12
13
14
15
16
17
18
19
  public int numFives () {
    return numFivesH (first, 0);
  }
  private static int numFivesH (Node x, int result) {
    if (x == null) return result;
    if (x.item == 5) result = result + 1;
    result = numFivesH (x.next, result);
    return result;
  }

For [5,11,5,5], the call tree is

call@3 ([5,11,5,5], 0)
  call@4 ([11,5,5], 1)
    call@5  ([5,5], 1)
      call@6  ([5], 2)
        call@7 ([], 3)
        retn@7 ([], 3) : 3
      retn@6  ([5], 2) : 3
    retn@5  ([5,5], 1) : 3
  retn@4 ([11,5,5], 1) : 3
retn@3 ([5,11,5,5], 0) : 3

Previous pageContentsNext page