PHP实现双链表删除与插入节点的方法示例


Posted in PHP onNovember 11, 2017

本文实例讲述了PHP实现双链表删除与插入节点的方法。分享给大家供大家参考,具体如下:

概述:

双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点。一般我们都构造双向循环链表。

实现代码:

<?php 
class node{
  public $prev;
  public $next;
  public $data;
  public function __construct($data,$prev=null,$next=null){
    $this->data=$data;
    $this->prev=$prev;
    $this->next=$next;
  }
}
class doubleLinkList{
  private $head;
  public function __construct()
  {
    $this->head=new node("head",null,null);
  }
  //插入节点
  public function insertLink($data){
    $p=new node($data,null,null);
    $q=$this->head->next;
    $r=$this->head;
    while($q){
      if($q->data>$data){
        $q->prev->next=$p;
        $p->prev=$q->prev;
        $p->next=$q;
        $q->prev=$p;
      }else{
      $r=$q;$q=$q->next;
      }
    }
    if($q==null){
      $r->next=$p;
      $p->prev=$r;
    }
  }
  //从头输出节点
  public function printFromFront(){
    $p=$this->head->next;
    $string="";
    while($p){
    $string.=$string?",":"";
    $string.=$p->data;
    $p=$p->next;
    }
    echo $string."<br>";
  }
  //从尾输出节点
  public function printFromEnd(){
    $p=$this->head->next;
    $r=$this->head;
    while($p){
    $r=$p;$p=$p->next;
    }
    $string="";
    while($r){
      $string.=$string?",":"";
      $string.=$r->data;
      $r=$r->prev;
    }
    echo $string."<br>";
  }
  public function delLink($data){
    $p=$this->head->next;
    if(!$p)
    return;
    while($p){
      if($p->data==$data)
      {
        $p->next->prev=$p->prev;
        $p->prev->next=$p->next;
        unset($p);
        return;
      }
      else{
        $p=$p->next;
      }
    }
    if($p==null)
    echo "没有值为{$data}的节点";
  }
}
$link=new doubleLinkList();
$link->insertLink(1);
$link->insertLink(2);
$link->insertLink(3);
$link->insertLink(4);
$link->insertLink(5);
$link->delLink(3);
$link->printFromFront();
$link->printFromEnd();
$link->delLink(6);

运行结果:

1,2,4,5
5,4,2,1,head
没有值为6的节点

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
php中的时间显示
Jan 18 PHP
discuz论坛 用户登录 后台程序代码
Nov 27 PHP
Apache环境下PHP利用HTTP缓存协议原理解析及应用分析
Feb 16 PHP
PHP获取时间排除周六、周日的两个方法
Jun 30 PHP
浅谈PHP正则表达式中修饰符/i, /is, /s, /isU
Oct 21 PHP
在PHP程序中使用Rust扩展的方法
Jul 03 PHP
PHP程序中的文件锁、互斥锁、读写锁使用技巧解析
Mar 21 PHP
PHP实现的浏览器检查类
Apr 11 PHP
Yii框架参数化查询中IN查询只能查询一个的解决方法
May 20 PHP
PHP PDOStatement::fetch讲解
Jan 31 PHP
Yii框架getter与setter方法功能与用法分析
Oct 22 PHP
php反序列化长度变化尾部字符串逃逸(0CTF-2016-piapiapia)
Feb 15 PHP
PHP实现基于栈的后缀表达式求值功能
Nov 10 #PHP
PHP实现基于图的深度优先遍历输出1,2,3...n的全排列功能
Nov 10 #PHP
PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法
Nov 10 #PHP
PHP简单实现循环链表功能示例
Nov 10 #PHP
浅谈使用 Yii2 AssetBundle 中 $publishOptions 的正确姿势
Nov 08 #PHP
php基于环形链表解决约瑟夫环问题示例
Nov 07 #PHP
PHP基于关联数组20行代码搞定约瑟夫问题示例
Nov 07 #PHP
You might like
php采集自中央气象台范围覆盖全国的天气预报代码实例
2015/01/04 PHP
PHP基于ORM方式操作MySQL数据库实例
2017/06/21 PHP
javascript日期转换 时间戳转日期格式
2011/11/05 Javascript
仿谷歌主页js动画效果实现代码
2013/07/14 Javascript
JQuery中DOM事件冒泡实例分析
2015/06/13 Javascript
jQuery中通过ajax调用webservice传递数组参数的问题实例详解
2016/05/20 Javascript
jQuery+php实时获取及响应文本框输入内容的方法
2016/05/24 Javascript
js中window.open的参数及注意注意事项
2016/07/06 Javascript
js实现控制textarea输入字符串的个数,鼠标按下抬起判断输入字符数
2016/10/25 Javascript
Vue.js中用webpack合并打包多个组件并实现按需加载
2017/02/17 Javascript
Vue2.0 axios前后端登陆拦截器(实例讲解)
2017/10/27 Javascript
AngularJS修改model值时,显示内容不变的实例
2018/09/13 Javascript
如何实现双向绑定mvvm的原理实现
2019/05/28 Javascript
Vue动态修改网页标题的方法及遇到问题
2019/06/09 Javascript
JavaScript接口实现方法实例分析
2020/05/16 Javascript
使用纯前端JavaScript实现Excel导入导出方法过程详解
2020/08/07 Javascript
Vue+Element ui 根据后台返回数据设置动态表头操作
2020/09/21 Javascript
python实现发送邮件功能代码
2017/12/14 Python
解决Spyder中图片显示太小的问题
2018/04/27 Python
对python实现合并两个排序链表的方法详解
2019/01/23 Python
Pycharm新建模板默认添加个人信息的实例
2019/07/15 Python
Python requests设置代理的方法步骤
2020/02/23 Python
django xadmin中form_layout添加字段显示方式
2020/03/30 Python
Python3将ipa包中的文件按大小排序
2020/04/17 Python
Python try except else使用详解
2021/01/12 Python
基于Html5实现的语音搜索功能
2019/05/13 HTML / CSS
Avène雅漾美国官方网站:敏感肌肤护理专家
2016/10/24 全球购物
加拿大国民体育购物网站:National Sports
2018/11/04 全球购物
娇韵诗香港官网:Clarins香港
2020/08/13 全球购物
Shell脚本如何向终端输出信息
2014/04/25 面试题
中年人生感言
2014/02/04 职场文书
小学英语课后反思
2014/04/26 职场文书
计算机求职信
2014/07/02 职场文书
2015年社区精神文明工作总结
2015/05/26 职场文书
中学音乐课教学反思
2016/02/18 职场文书
使用 Koa + TS + ESLlint 搭建node服务器的过程详解
2022/05/30 NodeJs