吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 758|回复: 0
收起左侧

[学习记录] 基于php实现的单链表

  [复制链接]
bugpig 发表于 2022-12-31 16:08
//链表结点   
    class node {   
        public $data;         //存储数据   
        public $next;                //下一结点   
         
        public function __construct($data) {   
            $this->data = $data;   
            $this->next = NULL;   
        }   
    }  
    //单链表   
    class linkList {   
        private $header;         //链表头结点  
         
        //构造方法   
        public function __construct($data = NULL) {   
            $this->header = new node ($data);   
        }   
        
        //添加结点数据   
        public function addLink($node) {   
            $current = $this->header;   
            while ( $current->next != NULL ) {   
                $current = $current->next;   
            }   
            $node->next = $current->next;   
            $current->next = $node;   
        }   
         
        //清空链表  
        public function clear(){  
            $this->header = NULL;  
        }   

        //获取链表   
        public function getLinkList() {   
            $current = $this->header;   
            if ($current->next == NULL) {   
                echo ("链表为空!");   
                return;   
            }   
            while ( $current->next != NULL ) {   
                echo $current->next->data . " ";   
                if ($current->next->next == NULL) {   
                    break;   
                }   
                $current = $current->next;   
            }   
        }   

        // 函数功能:对单链表进行逆序
        public function reverse(){
            $head = $this->header;
            //判断链表是否为空
            if($head==NULL || $head->next==NULL){
               echo "链表为空";
               return;
            }
            $pre=NULL;                 //前驱结点
            $cur=NULL;                 //当前结点
            $next=NULL;                //后继结点
            //把链表首结点变为尾结点
            $cur=$head->next;
            $next=$cur->next;
            $cur->next=NULL;
            $pre=$cur;
            $cur=$next;
            //使当前遍历到的结点cur指向其前驱结点
            while($cur->next!=NULL){
               $next=$cur->next;
               $cur->next=$pre;
               $pre=$cur;
               $cur=$cur->next;
               $cur=$next;
            }
            //结点最后一个结点指向倒数第二个结点
            $cur->next=$pre;
            //链表的头结点指向原来链表的尾结点
            $head->next=$cur;
       }
}  

    $lists = new linkList();   
    for($i=1;$i<8;$i++){
        $lists->addLink (new node ($i));   
    }
    echo "逆序前:";
    $lists->getLinkList();   
    $lists->reverse();
    echo "<br>逆序后:";
    $lists->getLinkList();
    //释放链表所占的空间  
    $lists->clear();

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-11 20:47

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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