Reversing a linkedlist recursively in c

后端 未结 9 1283
滥情空心
滥情空心 2020-12-07 23:33

The following code works fine when head is sent as a parameter to it. As I am new to C, I couldn\'t understand how it works. Help me out please.

struct node          


        
9条回答
  •  醉话见心
    2020-12-08 00:14

    /* Reverses a linked list, returns head of reversed list
    */
    NodePtr reverseList(NodePtr curr) {
        if (curr == NULL || curr->next == NULL) return curr; // empty or single element case
    
        NodePtr nextElement = curr->next;
        curr->next = NULL;
        NodePtr head = reverseList(nextElement);
        nextElement->next = curr;
        return head;
    }
    

提交回复
热议问题