Leetcode题库剑指 Offer 24. 反转链表(头插法 c实现)

思路

方法1:头插法

ret为返回链表的头部
head_last指向下一个加入ret的节点
每次将head取出使用头插法将其插入ret
然后head=head_last, head_last=head->next
如此循环直至head_last为NULL
举例:head: 1 -> 2 -> 3

head_last: 2 -> 3
head: 1 #将head插入ret链表
ret: 1

head: 2 -> 3
head_last: 3
head: 2 #将head插入ret链表
ret: 2 -> 1

head: 3
head_last: NULL
head: 3 #将head插入ret链表
ret: 3 -> 2 -> 1

head_last: NULL跳出循环

方法2:递归

使用递归,递归到head链表尾部,随着每一层递归的返回记录当前的head节点到新链表中,最后也能达到反转链表的效果

举例:
第一层:
head: 1 -> 2 -> 3
head->next 不为空
继续递归

第二层:
head: 2 -> 3
head->next 不为空
继续递归

第三层:
head: 3
head->next 为空
返回将当前节点加入新链表(ret = 3 -> NULL)

返回第二层:
返回将当前节点加入新链表(ret = 3 -> 2 -> NULL)

返回第一层:
返回将当前节点加入新链表(ret = 3 -> 2 -> 1 -> NULL)

代码

头插法

struct ListNode* reverseList(struct ListNode* head){
    struct ListNode *ret,*head_last;
    while(head != NULL){
        head_last = head->next;
        head->next = ret;
        ret = head;
        if(head_last == NULL) break;
        head = head_last;
    }
    return ret;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值