使用PHP实现单链表

Apr 18, 2018 pm 01:44 PM
php guna capai

这篇文章主要介绍了关于使用PHP实现单链表 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

单链表顾名思义就是一个链式数据结构,它有一个表头,并且除了最后一个节点外,所有节点都有其后继节点。如下图。

首先,我们写出链表节点的类。单链表中的每一个节点,都保存其数据域和后驱指针



[php] view plain copy


  1. //链表节点   
    class node {   
        public $id; //节点id   
        public $name; //节点名称   
        public $next; //下一节点   
         
        public function __construct($id, $name) {   
            $this->id = $id;   
            $this->name = $name;   
            $this->next = null;   
        }   
    }
    Salin selepas log masuk

链表中还有两个特别重要的方法,插入和删除。插入需要找到插入的位置,把前一个元素的next指针指向被插入的节点,并将被插入节点的next指针指向后一个节点,如下图左侧所示。而删除则是把前一个节点的next指针指向后一个节点,并返回被删除元素的数据内容,如下图右侧所示。



[php] view plain copy


  1. //单链表   
    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 = 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 . "的节点!<br>";   
            }   
        }  
      
        //判断连表是否为空  
        public function isEmpty(){  
                return $this->header == null;  
        }  
      
        //清空链表  
        public function clear(){  
                $this->header = null;  
        }   
      
        //获取链表   
        public function getLinkList() {   
            $current = $this->header;   
            if ($current->next == null) {   
                echo ("链表为空!");   
                return;   
            }   
            while ( $current->next != null ) {   
                echo &#39;id:&#39; . $current->next->id . &#39;   name:&#39; . $current->next->name . "<br>";   
                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, &#39;eeeeee&#39; ) );   
    $lists->addLink ( new node ( 1, &#39;aaaaaa&#39; ) );   
    $lists->addLink ( new node ( 6, &#39;ffffff&#39; ) );   
    $lists->addLink ( new node ( 4, &#39;dddddd&#39; ) );   
    $lists->addLink ( new node ( 3, &#39;cccccc&#39; ) );   
    $lists->addLink ( new node ( 2, &#39;bbbbbb&#39; ) );   
    $lists->getLinkList ();   
    echo "<br>-----------删除节点--------------<br>";   
    $lists->delLink ( 5 );   
    $lists->getLinkList ();  
    echo "<br>-----------更新节点名称--------------<br>";   
    $lists->updateLink ( 3, "222222" );   
    $lists->getLinkList ();  
    echo "<br>-----------获取节点名称--------------<br>";   
    echo $lists->getLinkNameById ( 5 );  
    echo "<br>-----------获取链表长度--------------<br>";   
    echo $lists->getLinkLength ();
    Salin selepas log masuk

相关推荐:

使用php来解析实现二级域名重定向


Atas ialah kandungan terperinci 使用PHP实现单链表. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Konfigurasi Projek CakePHP Konfigurasi Projek CakePHP Sep 10, 2024 pm 05:25 PM

Dalam bab ini, kita akan memahami Pembolehubah Persekitaran, Konfigurasi Umum, Konfigurasi Pangkalan Data dan Konfigurasi E-mel dalam CakePHP.

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

CakePHP Bekerja dengan Pangkalan Data CakePHP Bekerja dengan Pangkalan Data Sep 10, 2024 pm 05:25 PM

Bekerja dengan pangkalan data dalam CakePHP adalah sangat mudah. Kami akan memahami operasi CRUD (Buat, Baca, Kemas Kini, Padam) dalam bab ini.

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Penghalaan CakePHP Penghalaan CakePHP Sep 10, 2024 pm 05:25 PM

Dalam bab ini, kita akan mempelajari topik berikut yang berkaitan dengan penghalaan ?

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Pengesah Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

See all articles