栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

PHP单链表的基本操作

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP单链表的基本操作

前提

对于大多数的大一,大二的童鞋们来说,可能最操蛋的就是数据结构这个课了,什么链表,堆栈,队列,图,简直噩梦!对我也是,我也是在大三后实习后发现这个真的是个硬技能,

链表的实现

数据结构第一个就是链表了,链表分为两种有直接的数组形式的顺序链,这里不讨论,什么array_push(),array_pop(),函数基本能满足日常的需求,但报告老板,我就是想装个X

上代码吧
mElem=null;        $this->mNext=null;
    }
}class SinglelinkedList{     //头结点数据
    public $mElem;    //下一结点指针
    public $mNext;    //单链表长度
    public static $mLength=0;    public function __construct(){        $this->mElem=null;        $this->mNext=null;
    }    //返回单链表长度
      public static function getLength(){          return self::$mLength;
    }      public function getIsEmpty(){        if(self::$mLength==0 && $this->mNext==null){            return true;
        }        else{            return false;
        }
      }      public function clearSLL(){            if(self::$mLength>0){                while($this->mNext!=null){
                        $q=$this->mNext->mNext;                        $this->mNext=null;                        unset($this->mNext);                        $this->mNext=$q;
            }           self::$mLength=0;
        }
    }    public function getHeadCreateSLL($sarr){        $this->clearSLL();        if(is_array($sarr) and count($sarr)>0){            foreach ($sarr as $key => $value) {
                $p= new LNode;
                $p->mElem=$value;
                $p->mNext=$this->mNext;                $this->mNext=$p;                self::$mLength++;
            }
        }        else{            return false;
        }        return true;
    }     public function getTailCreateSLL($sarr){        $this->clearSLL();        if(is_array($sarr) and count($sarr)>0){
                $q=$this;                foreach($sarr as $value){
                        $p=new LNode;
                        $p->mElem=$value;
                        $p->mNext=$q->mNext;
                        $q->mNext=$p;
                        $q=$p;                        self::$mLength++;
            }
        }        else{                return false;
        }
    }     public function getElemForPos($i){        if(is_numeric($i) && $i0){
            $p=$this->mNext;            for ($j=1; $j < $i ; $j++) { 
                $q=$p->mNext;
                $p=$q;
            }            return $p->mElem;
        }        else{            return null;
        }
     }      public function getElemIsExist($value){        if($value){
            $p=$this;            while($p->mNext!=null and $p->mElem!=value){
                $q=$p->mNext;
                $p=$q;
            }            if($p->mElem==value){                return true;
            }            else{                return false;
            }
        }
      }      public function getElemPosition($value){        if($value){
            $p=$this;
            $pos=0;            while($p->mNext!=null and $p->mElem!=$value){
                $q=$p->mNext;
                $p=$q;
                $pos++;
            }            if($p->mElem==$value){                return $pos;
            }            else{                return -1;
            }
        }
      }        
        public function getInsertElem($i,$e){            if($imNext!=null and $j<$i){
                $q=$p->mNext;
                $p=$q;
                $j++;
            }
            $q=new LNode;
            $q->mElem=$e;
            $q->mNext=$p->mNext;
            $p->mNext=$q;            self::$mLength++;            return true;
        }      
    public function getDeleteElem($i){        if($i>self::$mLength || $i<1){                return false;
            }            else{
                $p=$this;
                $j=1;                while($j<$i){
                    $p=$p->mNext;
                    $j++;
                }
                $q=$p->mNext;
                $p->mNext=$q->mNext;                unset($q);                self::$mLength--;                return true;
            }
    }     public function getAllElem(){
        $all=array();        if(!$this->getIsEmpty()){
            $p=$this->mNext;            while($p->mNext){
                $all[]=$p->mElem;
                $p=$p->mNext;
            }            if($p->mElem)
                $all[]=$p->mElem;            return $all;
        }
     }     public function getElemUnique(){         if(!$this->getIsEmpty()){
                $p=$this;                while($p->mNext!=null){
                        $q=$p->mNext;
                        $ptr=$p;                        while($q->mNext!=null){                                if(strcmp($p->mElem,$q->mElem)===0){
                                    $ptr->mNext=$q->mNext;
                                    $q->mNext=null;                                    unset($q->mNext);
                                    $q=$ptr->mNext;                                    self::$mLength--;
                                }                                else{
                                    $ptr=$q;
                                    $q=$q->mNext;
                                }
                    }                    //处理最后一个元素
                if(strcmp($p->mElem,$q->mElem)===0){
                                $ptr->mNext=null;                                self::$mLength--;
                        }
                        $p=$p->mNext;
                }//end of while
            }   
    }
}///////////////test//////////$node=new SinglelinkedList;
$arr=array('gbw','michael','php','js');//$node->getHeadCreateSLL($arr);//print_r($node->getAllElem());$node->getTailCreateSLL($arr);echo $node->getElemForPos(2);
$pos=$node->getElemPosition('gbw');echo $pos;
$node->getDeleteElem($pos);
$node->getInsertElem(1,'gbw2');
print_r($node->getAllElem());

希望对大家的php程序设计有所帮助!



作者:michaelgbw
链接:https://www.jianshu.com/p/c571d7347023

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/228098.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号