zoukankan      html  css  js  c++  java
  • 链表翻转

    翻转链表(LeetCode206题)

    翻转成

    我们思考,当

    到底该怎样去思考,思考问题的重心在哪里?

    先说结论:思考问题的重心是当前如何处理当前节点?

    假设现在当前节点是头结点2,那么当发生翻转到底发生了什么?

    如果我们要将节点2指向节点1,但是之前是指向节点3的,为了下次能够访问到节点3,我们应该用一个指针保存节点2的下一个节点。

    即首先应该有:

    Next = current->next;

    这样我们将current节点,也就是节点2的下一个节点保存了下来。这样我们就可以放心的将节点2指向节点2之前的节点了。但是需要说明的是:我们无法通过指针的方式来获取当前节点的上一个节点,因此,我们需要实现保存当前节点的上一个节点。此时有

    Current->next = pre;

    这样,我们完成了当前节点指针的翻转。接下来,就是更新了。显然,我们应该先更新上一个节点为当前节点。即

    Pre = current;

    然后将当前节点更新为之前保存的下一个节点

    Current = next.

    这样将节点遍历到最后一个节点,翻转结束。

    总结:翻转指针的核心是建立三个指针索引,分别指向当前节点的上一个节点,当前节点,当前节点的下一个节点。对于链表而言,这种多指针思想是经常用的。

  • 相关阅读:
    Datasnap http用户验证
    Delphi 接口机制真相
    tfmxobject的序列化
    delphi md5算法
    delphi xe 窗体子控件实现窗体拖动
    Delphi笔记-自定义组件
    DELPHI RES资源文件使用方法
    Delphi中WebBrowser的使用技巧汇总
    Delphi XE调用第三方库Jni详细过程
    使用VLC进行屏幕广播
  • 原文地址:https://www.cnblogs.com/shaonianpi/p/12158672.html
Copyright © 2011-2022 走看看