package DataStructures.Lists;

public class CountSinglyLinkedListRecursion extends SinglyLinkedList {
  public static void main(String[] args) {
    CountSinglyLinkedListRecursion list = new CountSinglyLinkedListRecursion();
    for (int i = 1; i <= 5; ++i) {
      list.insert(i);
    }
    assert list.count() == 5;
  }

  /**
   * Calculate the count of the list manually using recursion.
   *
   * @param head head of the list.
   * @return count of the list.
   */
  private int countRecursion(Node head) {
    return head == null ? 0 : 1 + countRecursion(head.next);
  }

  @Override
  public int count() {
    return countRecursion(getHead());
  }
}

CountSinglyLinkedListRecursion