dmz社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 14615|回复: 223

[数据结构] 数据结构值PHP实现反转链表

  [复制链接]
  • TA的每日心情

    2024-11-19 20:46
  • 签到天数: 244 天

    [LV.8]以坛为家I

    4434

    主题

    1459

    帖子

    1万

    积分

    会|员

    Rank: 9Rank: 9Rank: 9

    积分
    10734
    发表于 2018-11-15 19:00:16 | 显示全部楼层 |阅读模式

    本站资源全部免费,回复即可查看下载地址!

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x
    1.常见方法分为迭代和递归,迭代是从头到尾,递归是从尾到头
    2.设置两个指针,old和new,每一项添加在new的后面,新链表头指针指向新的链表头
    3.old->next不能直接指向new,而是应该设置一个临时指针tmp,指向old->next指向的地址空间,保存原链表数据,然后old->next指向new,new往前移动到old处new=old,最后old=tmp取回数据
    while(old!=null){
              tmp=old->next
              old->next=new
              new=old
              old=tmp
    }
    [PHP] 纯文本查看 复制代码
    <?php
    class Node{
            public $data;
            public $next;
    }
    //头插法创建一个链表
    $linkList=new Node();
    $linkList->next=null;//头结点
    for($i=1;$i<=10;$i++){
            $node=new Node();
            $node->data="aaa{$i}";//创建新结点$node
            $node->next=$linkList->next;//$node->next指向头结点->next
            $linkList->next=$node;//头结点->next指向$node
    }
    
    var_dump($linkList);
    
    function ReverseList($pHead){
            $old=$pHead->next;//跳过头结点
            $new=null;
            $tmp=null;
            //反转过程
            while($old!=null){
                    $tmp=$old->next;
                    $old->next=$new;
                    $new=$old;
                    $old=$tmp;
            }   
            //给新链表加个头结点
            $newHead=new Node();
            $newHead->next=$new;
            var_dump($newHead);
    }
    ReverseList($linkList);

    [PHP] 纯文本查看 复制代码
    object(Node)#1 (2) {
      ["data"]=>
      NULL
      ["next"]=>
      object(Node)#11 (2) {
        ["data"]=>
        string(5) "aaa10"
        ["next"]=>
        object(Node)#10 (2) {
          ["data"]=>
          string(4) "aaa9"
          ["next"]=>
          object(Node)#9 (2) {
            ["data"]=>
            string(4) "aaa8"
            ["next"]=>
            object(Node)#8 (2) {
              ["data"]=>
              string(4) "aaa7"
              ["next"]=>
              object(Node)#7 (2) {
                ["data"]=>
                string(4) "aaa6"
                ["next"]=>
                object(Node)#6 (2) {
                  ["data"]=>
                  string(4) "aaa5"
                  ["next"]=>
                  object(Node)#5 (2) {
                    ["data"]=>
                    string(4) "aaa4"
                    ["next"]=>
                    object(Node)#4 (2) {
                      ["data"]=>
                      string(4) "aaa3"
                      ["next"]=>
                      object(Node)#3 (2) {
                        ["data"]=>
                        string(4) "aaa2"
                        ["next"]=>
                        object(Node)#2 (2) {
                          ["data"]=>
                          string(4) "aaa1"
                          ["next"]=>
                          NULL
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
    object(Node)#12 (2) {
      ["data"]=>
      NULL
      ["next"]=>
      object(Node)#2 (2) {
        ["data"]=>
        string(4) "aaa1"
        ["next"]=>
        object(Node)#3 (2) {
          ["data"]=>
          string(4) "aaa2"
          ["next"]=>
          object(Node)#4 (2) {
            ["data"]=>
            string(4) "aaa3"
            ["next"]=>
            object(Node)#5 (2) {
              ["data"]=>
              string(4) "aaa4"
              ["next"]=>
              object(Node)#6 (2) {
                ["data"]=>
                string(4) "aaa5"
                ["next"]=>
                object(Node)#7 (2) {
                  ["data"]=>
                  string(4) "aaa6"
                  ["next"]=>
                  object(Node)#8 (2) {
                    ["data"]=>
                    string(4) "aaa7"
                    ["next"]=>
                    object(Node)#9 (2) {
                      ["data"]=>
                      string(4) "aaa8"
                      ["next"]=>
                      object(Node)#10 (2) {
                        ["data"]=>
                        string(4) "aaa9"
                        ["next"]=>
                        object(Node)#11 (2) {
                          ["data"]=>
                          string(5) "aaa10"
                          ["next"]=>
                          NULL
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }



    回复

    使用道具 举报

    该用户从未签到

    35

    主题

    7850

    帖子

    1098

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    1098

    发表于 2018-11-15 19:18:01 | 显示全部楼层
    正需要,支持楼主大人了!
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    22

    主题

    7846

    帖子

    992

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    992

    发表于 2018-11-15 19:54:42 | 显示全部楼层
    支持一下:lol
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    39

    主题

    7819

    帖子

    1026

    积分

    终身会员[B]

    积分
    1026

    发表于 2018-11-15 20:04:09 | 显示全部楼层
    有竞争才有进步嘛
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    29

    主题

    8020

    帖子

    1015

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    1015

    发表于 2018-11-15 21:25:56 | 显示全部楼层
    正需要,支持楼主大人了!
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    40

    主题

    7912

    帖子

    1004

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    1004

    发表于 2018-11-15 21:33:16 | 显示全部楼层
    有竞争才有进步嘛
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    20

    主题

    7880

    帖子

    986

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    986

    发表于 2018-11-15 22:25:48 | 显示全部楼层
    支持一下:lol
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    18

    主题

    7781

    帖子

    928

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    928

    发表于 2018-11-15 22:30:33 | 显示全部楼层
    好好 学习了 确实不错
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    20

    主题

    7880

    帖子

    986

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    986

    发表于 2018-11-15 23:55:09 | 显示全部楼层
    珍惜生命,果断回帖。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    21

    主题

    7719

    帖子

    998

    积分

    终身会员[A]

    Rank: 7Rank: 7Rank: 7

    积分
    998

    发表于 2018-11-16 06:22:51 | 显示全部楼层
    支持一下:lol
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|小黑屋|本站代理|dmz社区

    GMT+8, 2024-12-24 00:08 , Processed in 1.226703 second(s), 41 queries .

    Powered by Discuz! X3.4 Licensed

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表