mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2025-01-25 09:01:38 +00:00
167 lines
2.8 KiB
PHP
167 lines
2.8 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* Doubly Linked List
|
||
|
*
|
||
|
* This list is linked to an avl tree for searching purpose!
|
||
|
*/
|
||
|
class DLL {
|
||
|
private $first;
|
||
|
private $last;
|
||
|
private $size;
|
||
|
private $avl;
|
||
|
|
||
|
function DLL() {
|
||
|
$this->avl = new AVLTree();
|
||
|
|
||
|
$this->first = null;
|
||
|
$this->last = null;
|
||
|
|
||
|
$this->size = 0;
|
||
|
}
|
||
|
|
||
|
function getIterator() {
|
||
|
return new NodeIterator($this->first);
|
||
|
}
|
||
|
|
||
|
final function getSize() {
|
||
|
return $this->size;
|
||
|
}
|
||
|
|
||
|
final function isEmpty() {
|
||
|
return ($this->size == 0);
|
||
|
}
|
||
|
|
||
|
function getFirst() {
|
||
|
return $this->first;
|
||
|
}
|
||
|
|
||
|
function getLast() {
|
||
|
return $this->last;
|
||
|
}
|
||
|
|
||
|
function addNode($data,$before = null) { // add a node
|
||
|
if($this->findNode($data->getID()) != null) {
|
||
|
return false;
|
||
|
}
|
||
|
$n = new DLLnode($data);
|
||
|
if($before == null) {
|
||
|
//insert as last
|
||
|
if($this->last != null) {
|
||
|
$this->last->setChild($n);
|
||
|
}
|
||
|
$n->setParent($this->last);
|
||
|
$this->last = $n;
|
||
|
}
|
||
|
else {
|
||
|
//insert before
|
||
|
$b = $this->findNode($before);
|
||
|
if($b != null) {
|
||
|
if($b == $this->first) {
|
||
|
$this->first = $n;
|
||
|
}
|
||
|
$tmp = $b->getParent();
|
||
|
$b->setParent($n);
|
||
|
$n->setChild($b);
|
||
|
if($tmp != null) {
|
||
|
$tmp->setChild($n);
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
$this->addNode($data);
|
||
|
return null;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if($this->first == null) {
|
||
|
$this->first = $n;
|
||
|
}
|
||
|
|
||
|
$this->avl->insert($n); // pass on to avl tree
|
||
|
$this->size++;
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
function removeNode($id) { // remove a node
|
||
|
#$this->avl->inorder();
|
||
|
|
||
|
$n = $this->findNode($id);
|
||
|
if($n != null) {
|
||
|
|
||
|
$p = $n->getParent();
|
||
|
$c = $n->getChild();
|
||
|
|
||
|
if($c != null) {
|
||
|
$c->setParent($p);
|
||
|
if($p != null) {
|
||
|
$p->setChild($c);
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
if($p != null) {
|
||
|
$p->setChild(null);
|
||
|
}
|
||
|
$this->last = $p;
|
||
|
}
|
||
|
|
||
|
if($p == null) {
|
||
|
if($c != null) {
|
||
|
$c->setParent(null);
|
||
|
$this->first = $c;
|
||
|
}
|
||
|
else {
|
||
|
$this->first = null;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$this->avl->remove($id); // pass on to avl tree
|
||
|
$this->size--;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
function findNode($id) {
|
||
|
return $this->avl->find($id);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* List nodes
|
||
|
*/
|
||
|
|
||
|
class DLLnode {
|
||
|
private $parent;
|
||
|
private $child;
|
||
|
public $data;
|
||
|
|
||
|
function DLLNode($d) {
|
||
|
$this->parent = null;
|
||
|
$this->child = null;
|
||
|
$this->data = $d; // actual data
|
||
|
}
|
||
|
|
||
|
final function getParent() {
|
||
|
return $this->parent;
|
||
|
}
|
||
|
|
||
|
final function setParent($p) {
|
||
|
$this->parent = $p;
|
||
|
}
|
||
|
|
||
|
final function getChild() {
|
||
|
return $this->child;
|
||
|
}
|
||
|
|
||
|
final function setChild($c) {
|
||
|
$this->child = $c;
|
||
|
}
|
||
|
|
||
|
final function getIterator() {
|
||
|
return new NodeIterator($this);
|
||
|
}
|
||
|
|
||
|
function getID() {
|
||
|
return $this->data->getID();
|
||
|
}
|
||
|
}
|
||
|
?>
|