力扣刷题时发现力扣的Listnode head指的实际上是第一个数据节点,也就是头指针,而不是我们平时习惯使用的头节点,这里需要注意的是头节点和头指针的差别。头节点是在链表的第一个数据节点之前,而此时的头指针指向的实际上是头节点,头节点可以不带数据,也可以带一些特殊的数据比如链表长度等,这种情况下判断链表是否为空就可以使用if(head -> next == NULL)。而头指针一般指向的是链表的第一个数据节点,而这也是力扣上单链表的head所表示的含义,因此力扣上写相关单链表的问题可以注意,有一些题比如删除倒数第k个链表这种题,如果使用总数减去所给数拿到正数的数字然后进行遍历的话,需要注意此问题否则会导致计算的链表长度出错。
下面题目就是本人对于该head的理解,平时自己编程习惯了,总是会将head->next赋值给h。然后计数的时候就会导致错误。