• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php实现单链表的实例代码_PHP

php 搞代码 3年前 (2022-01-25) 17次浏览 已收录 0个评论

复制代码 代码如下:
<?php

//链表节点
class node {
public $id; //节点id
public $name; //节点名称
public $next; //下一节点

public function __construct($id, $name) {
$this->id = $id;
$this->name = $name;
$this->next = null;
}
}

//单链表
class singelLinkList {
private $header; //链表头节点

//构造方法
public function __construct($id = null, $name = null) {
$this->header = new node ( $id, $name, null );
}

//获取链表长度
public function getLinkLength() {
$i = 0;
$current = $this->header;
while ( $current->next != null ) {
$i ++;
$current = $current->next;
}
return $i;
}

//添加节点数据
public function addLink($node) {
$current = $this->header;
while ( $current->next != null ) {
if ($current->next->id > $node->id) {
break;
}
$current = $current->next;
}
$node->next = $current->next;
$current->next = $node;
}

//删除链表节点
public function delLink($id) {
$current = $this->header;
$flag =*本文来源gaodai#ma#com搞@代~码^网+搞代gaodaima码 false;
while ( $current->next != null ) {
if ($current->next->id == $id) {
$flag = true;
break;
}
$current = $current->next;
}
if ($flag) {
$current->next = $current->next->next;
} else {
echo “未找到id=” . $id . “的节点!
“;
}
}

//获取链表
public function getLinkList() {
$current = $this->header;
if ($current->next == null) {
echo (“链表为空!”);
return;
}
while ( $current->next != null ) {
echo ‘id:’ . $current->next->id . ‘ name:’ . $current->next->name . “
“;
if ($current->next->next == null) {
break;
}
$current = $current->next;
}
}

//获取节点名字
public function getLinkNameById($id) {
$current = $this->header;
if ($current->next == null) {
echo “链表为空!”;
return;
}
while ( $current->next != null ) {
if ($current->id == $id) {
break;
}
$current = $current->next;
}
return $current->name;
}

//更新节点名称
public function updateLink($id, $name) {
$current = $this->header;
if ($current->next == null) {
echo “链表为空!”;
return;
}
while ( $current->next != null ) {
if ($current->id == $id) {
break;
}
$current = $current->next;
}
return $current->name = $name;
}
}

$lists = new singelLinkList ();
$lists->addLink ( new node ( 5, ‘eeeeee’ ) );
$lists->addLink ( new node ( 1, ‘aaaaaa’ ) );
$lists->addLink ( new node ( 6, ‘ffffff’ ) );
$lists->addLink ( new node ( 4, ‘dddddd’ ) );
$lists->addLink ( new node ( 3, ‘cccccc’ ) );
$lists->addLink ( new node ( 2, ‘bbbbbb’ ) );
$lists->getLinkList ();
echo “
———–删除节点————–
“;
$lists->delLink ( 5 );
$lists->getLinkList ();

echo “
———–更新节点名称————–
“;
$lists->updateLink ( 3, “222222” );
$lists->getLinkList ();

echo “
———–获取节点名称————–
“;
echo $lists->getLinkNameById ( 5 );

echo “
———–获取链表长度————–
“;
echo $lists->getLinkLength ();
?>


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php实现单链表的实例代码_PHP
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址