美文网首页
leetcode--206--反转链表

leetcode--206--反转链表

作者: minningl | 来源:发表于2020-12-06 15:14 被阅读0次

    题目:
    反转一个单链表。

    示例:

    输入: 1->2->3->4->5->NULL
    输出: 5->4->3->2->1->NULL
    进阶:
    你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

    链接:https://leetcode-cn.com/problems/reverse-linked-list

    思路:
    1、尾递归。

    Python代码:

    # Definition for singly-linked list.
    # class ListNode(object):
    #     def __init__(self, x):
    #         self.val = x
    #         self.next = None
    
    class Solution(object):
    
        def reserse(self, guard, head):
            if (head==None):
                return guard
            temp = head.next
            head.next = guard
            return self.reserse(head, temp)
    
        def reverseList(self, head):
            """
            :type head: ListNode
            :rtype: ListNode
            """
            return self.reserse(None, head)
    

    C++代码:

    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode(int x) : val(x), next(NULL) {}
     * };
     */
    class Solution {
    public:
    
        ListNode* reverse(ListNode* guard, ListNode* head){
            if (head==nullptr){
                return guard;
            }
            ListNode* temp = head->next;
            head->next = guard;
            return reverse(head, temp);
        }
    
        ListNode* reverseList(ListNode* head) {
            return reverse(nullptr, head);
        }
    };
    

    相关文章

      网友评论

          本文标题:leetcode--206--反转链表

          本文链接:https://www.haomeiwen.com/subject/dgmowktx.html