Penjelasan terperinci tentang pelaksanaan struktur data bagi baris gilir dan timbunan PHP

WBOY
Lepaskan: 2024-05-07 09:42:01
asal
369 orang telah melayarinya

Baris gilir mengikut prinsip "masuk dahulu, keluar dahulu" dan boleh dilaksanakan menggunakan tatasusunan atau senarai terpaut; Kaedah pelaksanaan khusus termasuk: pelaksanaan tatasusunan baris gilir, pelaksanaan senarai terpaut baris gilir, pelaksanaan tatasusunan tindanan dan pelaksanaan senarai terpaut tindanan. Kes praktikal menunjukkan aplikasi baris gilir dan tindanan dalam pencetakan mesej dan pembalikan tatasusunan.

PHP 队列和堆栈的数据结构实现详解

Penjelasan terperinci tentang pelaksanaan struktur data bagi baris gilir dan tindanan PHP

Baris gilir dan tindanan ialah struktur data linear biasa. Mereka mempunyai sifat unik dan digunakan secara meluas dalam pelbagai aplikasi. Artikel ini akan memperkenalkan pelaksanaan struktur data baris gilir dan tindanan dalam PHP dan menyediakan kes praktikal.

Barisan

Barisan mengikut prinsip "masuk dahulu, keluar dahulu" (FIFO). Elemen tertua yang dimasukkan dalam baris gilir akan dialih keluar terlebih dahulu. Baris gilir boleh dilaksanakan menggunakan tatasusunan atau senarai terpaut.

Pelaksanaan tatasusunan:

class Queue
{
    private $queue = [];

    public function enqueue($item)
    {
        $this->queue[] = $item;
    }

    public function dequeue()
    {
        if (empty($this->queue)) {
            throw new Exception("Queue is empty");
        }
        return array_shift($this->queue);
    }
}
Salin selepas log masuk

Pelaksanaan senarai terpaut:

class Node
{
    public $data;
    public $next;

    public function __construct($data)
    {
        $this->data = $data;
        $this->next = null;
    }
}

class Queue
{
    private $head;
    private $tail;

    public function enqueue($item)
    {
        $node = new Node($item);
        if (empty($this->head)) {
            $this->head = $node;
            $this->tail = $node;
        } else {
            $this->tail->next = $node;
            $this->tail = $node;
        }
    }

    public function dequeue()
    {
        if (empty($this->head)) {
            throw new Exception("Queue is empty");
        }
        $item = $this->head->data;
        $this->head = $this->head->next;
        if (empty($this->head)) {
            $this->tail = null;
        }
        return $item;
    }
}
Salin selepas log masuk

Kes praktikal: Menggunakan baris gilir untuk mencetak mesej

$queue = new Queue();
$queue->enqueue("Hello");
$queue->enqueue("World");
while (!$queue->isEmpty()) {
    echo $queue->dequeue() . "<br>";
}
Salin selepas log masuk

Stack

Listindan pertama

Ikutkan

LIT bertindan dahulu . Elemen yang dimasukkan terakhir dalam timbunan akan dialih keluar terlebih dahulu. Tindanan boleh dilaksanakan menggunakan tatasusunan atau senarai terpaut.

Pelaksanaan tatasusunan:

class Stack
{
    private $stack = [];

    public function push($item)
    {
        $this->stack[] = $item;
    }

    public function pop()
    {
        if (empty($this->stack)) {
            throw new Exception("Stack is empty");
        }
        return array_pop($this->stack);
    }
}
Salin selepas log masuk
Pelaksanaan senarai terpaut:

class Node
{
    public $data;
    public $next;

    public function __construct($data)
    {
        $this->data = $data;
        $this->next = null;
    }
}

class Stack
{
    private $top;

    public function push($item)
    {
        $node = new Node($item);
        $node->next = $this->top;
        $this->top = $node;
    }

    public function pop()
    {
        if (empty($this->top)) {
            throw new Exception("Stack is empty");
        }
        $item = $this->top->data;
        $this->top = $this->top->next;
        return $item;
    }
}
Salin selepas log masuk
Kes praktikal:

Gunakan tindanan untuk membalikkan tatasusunan🎜
$stack = new Stack();
$array = [1, 2, 3, 4, 5];
foreach ($array as $item) {
    $stack->push($item);
}
$reversedArray = [];
while (!$stack->isEmpty()) {
    $reversedArray[] = $stack->pop();
}
print_r($reversedArray);
Salin selepas log masuk

Atas ialah kandungan terperinci Penjelasan terperinci tentang pelaksanaan struktur data bagi baris gilir dan timbunan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!