什么是链表?(依据百度词条查询而得)

链表是一种物理存储单元上非连续、非顺序的存储结构数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每个元素称为结点)组成,结点能够在执行时动态生成。每个结点包含两个部分:一个是存储数据元素的数据域,还有一个是存储下一个结点地址的指针域。

经过查询资料和观摩了站点不同版本号的链表后。小弟自己尝试着写了一个PHP版本号的单链表,希望对大家理解链表有所帮助。

<?php

//定义结点

class Node{

    public $id;//结点ID

    public $data;//结点数据

    public $next;//指向下一结点

    public function __construct($id,$data){

        $this->id=$id;

        $this->data=$data;

        $this->next=NULL;

    }

}

class Linklist{

    private $head;//定义头结点

    public function __construct($id=0,$data=NULL){

        $this->head=new Node($id,$data);

    }

    //插入结点

    public function addNode($node){

        $head=$this->head;

        //插入之前检查ID是否冲突

        if($this->getNode($node->id)!=false){

            echo "您要插入的ID为".$node->id."数据为".$node->data."的结点已经存在该ID。请改动ID后重试<br>";

            return false;

        }

        while($head->next!=NULL){

            if($head->next->id >= $node->id){

                break;

            }

            $head=$head->next;

        }

        $node->next=$head->next;

        $head->next=$node;



    }



    //删除结点

    public function delNode($id){

        $head=$this->head;

        $temp=false;

        //注意。删除操作须要找到须要删除的前一个结点

        while($head->next != NULL){

            if($head->next->id==$id){

                $temp=true;

                break;

            }

            $head=$head->next;

        }

        if($temp==true){

            if($head->next->next==null){

                $head->next=NULL;

            }

            else

                $head->next=$head->next->next;

            

        return true;

    }

    else {

        echo '未找到id为'.$id.'的结点<br>';

    }

    }



    //获取链表

    public  function getList(){

        $head=$this->head;

        if($head->next==NULL){

            echo '该链表为空';

        }

        while($head->next !=NULL){

            if($head->id != 0)

            echo 'ID为'.$head->id.'的结点中的数据为'.$head->data.'<br/>';

            $head=$head->next;

        }

            echo 'ID为'.$head->id.'的结点中的数据为'.$head->data;

    }



    //获取结点

    public function getNode($id){

        $head=$this->head;

        while($head !=NULL){

            if($head->id==$id)

                return $head->data;

            $head=$head->next;

        }

        return false;

    }



    //获取长度

    public function getLength(){

        $head=$this->head;

        $num=0;

        while($head->next !=NULL){

            $num++;

            $head=$head->next;

        }

        return $num;

    }

}

$a=new Linklist;

$a->addNode(new Node(1,"Hello Word"));

$a->addNode(new Node(2,3));

$a->addNode(new Node(2,11123));

$a->addNode(new Node(3,11123));

$a->getList();

$b=$a->getNode(3);

$c=$a->getLength();

var_dump($b);

var_dump($c);

?>

最后为測试代码,以下是測试结果:

小弟初学。哪里不正确的希望大家能够包容下。给点建议。

浅谈PHP数据结构之单链表的更多相关文章

  1. Python数据结构之单链表

    Python数据结构之单链表 单链表有后继结点,无前继结点. 以下实现: 创建单链表 打印单链表 获取单链表的长度 判断单链表是否为空 在单链表后插入数据 获取单链表指定位置的数据 获取单链表指定元素 ...

  2. javascript数据结构之单链表

    下面是用javascript实现的单链表,但是在输出的时候insert方法中存在问题,chrome的console报错说不能读取空的属性,调试了很久都没有通过,先在这里存着,以后再来修改一下. //数 ...

  3. 数据结构之单链表的实现-java

    一.单链表基本概念 单链表是一种链式存取的数据结构,用一组地址任意的存储单元(一般是非连续存储单元)存放线性表中的数据元素.链表中的数据是以结点来表示的,每个结点的构成:元素data + 指针next ...

  4. python 数据结构之单链表的实现

    链表的定义: 链表(linked list)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址.由于每个结点都包含了可以链接起来的地址信息,所以用一个变量就 ...

  5. 数据结构(一) 单链表的实现-JAVA

    数据结构还是很重要的,就算不是那种很牛逼的,但起码得知道基础的东西,这一系列就算是复习一下以前学过的数据结构和填补自己在这一块的知识的空缺.加油.珍惜校园中自由学习的时光.按照链表.栈.队列.排序.数 ...

  6. 浅谈PHP数据结构之栈

    今天開始进阶自己的PHP,首先一切的编程语言都须要修炼自己的"内功",何为程序猿的"内功",我想大概就是数据结构和算法了吧 .毕竟是灵魂,是普通程序猿到高级程序 ...

  7. 数据结构 - 静态单链表的实行(C语言)

    静态单链表的实现 1 静态链表定义 静态链表存储结构的定义如下: /* 线性表的静态链表存储结构 */ #define MAXSIZE 1000 /* 假设链表的最大长度是1000 */ typede ...

  8. 数据结构 - 动态单链表的实行(C语言)

    动态单链表的实现 1 单链表存储结构代码描述 若链表没有头结点,则头指针是指向第一个结点的指针. 若链表有头结点,则头指针是指向头结点的指针. 空链表的示意图: 带有头结点的单链表: 不带头结点的单链 ...

  9. 【数据结构】单链表介绍及leetcode206题反转单链表python实现

    题目传送门:https://leetcode-cn.com/problems/reverse-linked-list/ 文章目录 单链表介绍 链表 概念 种类 优缺点 单链表(slist) leetc ...

随机推荐

  1. HTML 表格与表单 个人简历

    <title>个人简历</title></head> <body background="1e30e924b899a9015b946ac41f950 ...

  2. 右边根据左边的高度自动居中只需要两行CSS就可以完成

    右边根据左边的高度自动居中只需要两行CSS就可以完成 <style type="text/css" > div{ display: inline-block; vert ...

  3. fcc 响应式框架Bootstrap 练习2

    text-primary 属性值使标题直接变成了红色,text-center使标题直接居中 <h2 class="text-primary  text-center"> ...

  4. Python元类(metaclass)以及元类实现单例模式

    这里将一篇写的非常好的文章基本照搬过来吧,这是一篇在Stack overflow上很热的帖子,我看http://blog.jobbole.com/21351/这篇博客对其进行了翻译. 一.理解类也是对 ...

  5. django-Celery分布式队列简单使用

    介绍: Celery 是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必需工具. 它是一个专注于实时处理的任务队列,同时也支持任务调度. worker:是一个独立的进程, ...

  6. 【转载】文件上传Expected MultipartHttpServletRequest: is a MultipartResolver错误解决

    引入包commons-fileupload-*.jar,版本号可以根据项目情况调整: 在spring mvc配置文件中增加配置,文件大小限制可根据项目情况调整: <!-- 上传文件拦截,设置最大 ...

  7. js 字符串,数组扩展

    console.log(Array.prototype.sort)//ƒ substring() { [native code] } console.log(String.prototype.subs ...

  8. C++入职学习篇--代码规范(持续更新)

    C++入职学习篇--代码规范(持续更新) 一.头文件规范 在头文件中大家一般会定义宏.引入库函数.声明.定义全局变量等,在设计时最后进行分类,代码示范(自己瞎琢磨的,请多多指点): #ifndef T ...

  9. Codeforces 918D/917B - MADMAX

    传送门:http://codeforces.com/contest/918/problem/D 本题是一个组合游戏问题——DAG上的动态规划问题. 有一张有向无环图(DAG).有两个玩家在这张图上进行 ...

  10. 《hello-world》第八次团队作业:Alpha冲刺-Scrum Meeting 5

    项目 内容 这个作业属于哪个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验十二 团队作业8:软件测试与Alpha冲刺 团队名称 <hello--worl ...