> 백엔드 개발 > PHP 튜토리얼 > PHP 实现单链表

PHP 实现单链表

WBOY
풀어 주다: 2016-06-23 13:51:52
원래의
1146명이 탐색했습니다.


header("Content-type:text/html;charset=utf-8");
//链表节点 
class node { 
    public static $count = -1; //节点id 
    public $name; //节点名称 
    public $next; //下一节点 
    public $id;

    public function __construct($name) { 
        $this->id = self::$count;
        $this->name = $name; 
        $this->next = null; 
        self::$count += 1;
    } 
}
//单链表 
class singelLinkList { 
    private $header;
    private $current;
    public $count;
   
    //构造方法 
    public function __construct($data = null) { 
        $this->header = new node ($data);
        $this->current = $this->header; 
        $this->count = 0;
    } 

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

    //删除链表节点 
    public function delLink($id) { 
        $current = $this->header; 
        $flag = false; 
        while ( $current->next != null ) { 
            if ($current->next->id == $id) { 
                $flag = true; 
                break; 
            } 
            $current = $current->next; 
        } 
        if ($flag) { 
            $this->count--;
            $current->next = $current->next->next; 
        } else { 
            echo "未找到id=" . $id . "的节点!
"; 
        } 
    }

    //获取链表 
    public function getLinkList() { 
        $this->checkNull();
        $current = $this->header; 
        while ( $current->next != null ) { 
            echo 'id:' . $current->next->id . '   name:' . $current->next->name . "
"; 
            if ($current->next->next == null) { 
                break; 
            } 
            $current = $current->next; 
        } 
    } 

        //获取长度
    public function getLinkLength()
    {
        echo $this->count;
    }

    //获取当前节点
    public function getCurrent()
    {
        $this->checkNull();
        echo '当前节点id:' . $this->current->next->id . '   name:' . $this->current->next->name . "
"; 
    }

    //判断是否为空
    public function checkNull()
    {
        if ($this->header->next == null) { 
            echo "链表为空!"; 
            exit;
        } 
    }

    //获取节点名字 
    public function getLinkById($id) { 
        $this->checkNull();
        $current = $this->header; 
        while ( $current->next != null ) { 
            if ($current->id == $id) { 
                break; 
            } 
            $current = $current->next; 
        } 
        echo '修改后id:' . $current->id . '   name:' . $current->name . "
"; 
    } 

    //更新节点名称 
    public function updateLink($id, $name) { 
        $this->checkNull();
        $current = $this->header; 
        while ( $current->next != null ) { 
            if ($current->id == $id) { 
                break; 
            } 
            $current = $current->next; 
        } 
        return $current->name = $name; 
    }
}
$list = new singelLinkList (); 
$list->addLink ( new node ('aaaaaa' ) ); 
$list->addLink ( new node ('bbbbbb' ) ); 
$list->addLink ( new node ('cccccc' ) ); 
$list->addLink ( new node ('dddddd' ) ); 
echo "所有链表节点:
";
$list->getLinkList(); 
echo "
";
echo "当前链表末位节点:
";
$list->getCurrent();
echo "
";
echo "修改链表节点id为0的:
";
$list->updateLink(0, '2222222');
echo "查找id为0的节点:
";
$list->getLinkById(0); 
echo "
";
echo "删除链表节点id为0:
";
$list->delLink(0); 
echo "所有链表节点:
";
$list->getLinkList(); 
echo "
";
echo "所有链表节点:
";
$list->getLinkLength (); 
?>

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿