资源经验分享LeetCode初级算法--链表01:反转链表

LeetCode初级算法--链表01:反转链表

2019-11-09 | |  96 |   0

原标题:LeetCode初级算法--链表01:反转链表

原文来自:博客园      原文链接:https://www.cnblogs.com/aimi-cn/p/11716712.html


一、引子

这是由LeetCode官方推出的的经典面试题目清单~
这个模块对应的是探索的初级算法~旨在帮助入门算法。我们第一遍刷的是leetcode推荐的题目。
查看完整的剑指Offer算法题解析请点击github链接:
github地址

二、题目

反转一个单链表。

示例:

输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

进阶:

你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

1、思路

这个题对我来说还是有点难度了,其实原理不难,我们我们使用三个指针,分别指向当前遍历到的结点、它的前一个结点以及后一个结点。

在遍历的时候,做当前结点的尾结点和前一个结点的替换。

因为这个题目之前在刷LeetCode的时候已经做过详细的图解说明 大家看链接就可以:https://blog.csdn.net/baidu_31657889/article/details/91552141

2、编程实现

python

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

本文由博客一文多发平台 OpenWrite 发布!

免责声明:本文来自互联网新闻客户端自媒体,不代表本网的观点和立场。

合作及投稿邮箱:E-mail:editor@tusaishared.com

上一篇:LeetCode初级算法--排序和搜索01:第一个错误的版本

下一篇:LeetCode初级算法--链表02:合并两个有序链表

用户评价
全部评价

热门资源

  • Python 爬虫(二)...

    所谓爬虫就是模拟客户端发送网络请求,获取网络响...

  • TensorFlow从1到2...

    原文第四篇中,我们介绍了官方的入门案例MNIST,功...

  • TensorFlow从1到2...

    “回归”这个词,既是Regression算法的名称,也代表...

  • 机器学习中的熵、...

    熵 (entropy) 这一词最初来源于热力学。1948年,克...

  • TensorFlow2.0(10...

    前面的博客中我们说过,在加载数据和预处理数据时...