php链表用法实例分析
发布:smiling 来源: PHP粉丝网 添加日期:2021-06-10 10:39:39 浏览: 评论:0
这篇文章主要介绍了php链表用法,实例分析了php创建链表及针对链表节点的增加、删除、更新与遍历等常用操作,需要的朋友可以参考下。
本文实例讲述了php链表用法,分享给大家供大家参考,具体如下:
这里简单介绍了php链表的基本用法,包括链表节点的创建、遍历、更新等操作。
- <?php
- /**
- * @author MzXy
- * @copyright 2011
- * @param PHP链表
- */
- /**
- *
- *节点类
- */
- class Node
- {
- private $Data;//节点数据
- private $Next;//下一节点
- public function setData($value){
- $this->Data=$value;
- }
- public function setNext($value){
- $this->Next=$value;
- }
- public function getData(){
- return $this->Data;
- }
- public function getNext(){
- return $this->Next;
- }
- public function __construct($data,$next){
- $this->setData($data);
- $this->setNext($next);
- }
- }//功能类
- class LinkList
- {
- private $header;//头节点
- private $size;//长度
- public function getSize(){
- $i=0;
- $node=$this->header;
- while($node->getNext()!=null)
- { $i++;
- $node=$node->getNext();
- }
- return $i;
- }
- public function setHeader($value){
- $this->header=$value;
- }
- public function getHeader(){
- return $this->header;
- }
- public function __construct(){
- header("content-type:text/html; charset=utf-8");
- $this->setHeader(new Node(null,null));
- }
- /**
- *@author MzXy
- *@param $data--要添加节点的数据
- *
- */
- public function add($data)
- {
- $node=$this->header;
- while($node->getNext()!=null)
- {
- $node=$node->getNext();
- }
- $node->setNext(new Node($data,null));
- }
- /**
- *@author MzXy
- *@param $data--要移除节点的数据
- *
- */
- public function removeAt($data)
- {
- $node=$this->header;
- while($node->getData()!=$data)
- {
- $node=$node->getNext();
- }
- $node->setNext($node->getNext());
- $node->setData($node->getNext()->getData());
- }
- /**
- *@author MzXy
- *@param 遍历
- *
- */
- public function get()
- {
- $node=$this->header;
- if($node->getNext()==null){
- print("数据集为空!");
- return;
- }
- while($node->getNext()!=null)
- {
- print($node->getNext()->getData());
- if($node->getNext()->getNext()==null){break;}
- $node=$node->getNext();
- }
- }
- /**
- *@author MzXy
- *@param $data--要访问的节点的数据
- * @param 此方法只是演示不具有实际意义
- *
- */
- public function getAt($data)
- {
- $node=$this->header->getNext();
- if($node->getNext()==null){
- print("数据集为空!");
- return;
- }
- while($node->getData()!=$data)
- {
- if($node->getNext()==null){break;}
- $node=$node->getNext();
- }
- return $node->getData();
- }
- /**
- *@author MzXy
- *@param $value--需要更新的节点的原数据 --$initial---更新后的数据
- *
- */
- public function update($initial,$value)
- {
- $node=$this->header->getNext();
- if($node->getNext()==null){
- print("数据集为空!");
- return;
- }
- while($node->getData()!=$data)
- {
- if($node->getNext()==null){break;}
- $node=$node->getNext();
- }
- $node->setData($initial);
- }
- }
- ?>
Tags: php链表
- 上一篇:php结合curl实现多线程抓取
- 下一篇:PHP实现全角字符转为半角方法汇总
相关文章
- ·PHP小教程之实现链表(2021-02-10)
- ·PHP实现找出链表中环的入口节点(2021-08-30)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)