


Bagaimana untuk menulis algoritma carian mendalam-pertama untuk graf menggunakan PHP
Cara menulis algoritma carian depth-first untuk graf menggunakan PHP
Depth-first search (DFS) ialah algoritma traversal graf yang meneroka sedalam mungkin di sepanjang cawangan dalam graf sehingga ia tidak lagi dapat diteruskan. Kemudian undur ke nod sebelumnya dan teruskan meneroka cawangan lain sehingga semua nod telah dilawati. Dalam artikel ini, kita akan belajar cara menulis algoritma carian mendalam-pertama untuk graf menggunakan PHP.
Pertama, kami mencipta kelas nod untuk mewakili nod dalam graf:
class Node { public $value; public $visited; public $neighbors; public function __construct($value) { $this->value = $value; $this->visited = false; $this->neighbors = array(); } public function addNeighbor($neighbor) { array_push($this->neighbors, $neighbor); } }
Setiap nod mempunyai nilai, teg yang dilawati dan tatasusunan jiran. Dalam pembina, kami memulakan sifat ini.
Seterusnya, kami mencipta kelas graf dan melaksanakan algoritma carian kedalaman pertama:
class Graph { public $nodes; public function __construct() { $this->nodes = array(); } public function addNode($value) { $node = new Node($value); array_push($this->nodes, $node); } public function getNode($value) { foreach ($this->nodes as $node) { if ($node->value == $value) { return $node; } } return null; } public function addEdge($value1, $value2) { $node1 = $this->getNode($value1); $node2 = $this->getNode($value2); $node1->addNeighbor($node2); $node2->addNeighbor($node1); } public function depthFirstSearch($startNode) { $stack = new SplStack(); $stack->push($startNode); $startNode->visited = true; while (!$stack->isEmpty()) { $currentNode = $stack->pop(); echo $currentNode->value . " "; foreach ($currentNode->neighbors as $neighbor) { if (!$neighbor->visited) { $stack->push($neighbor); $neighbor->visited = true; } } } } }
Pembina memulakan tatasusunan nod kosong. Kaedah addNode digunakan untuk menambah nod baharu pada graf, dan kaedah getNode digunakan untuk mendapatkan objek nod melalui nilai nod.
Kaedah addEdge digunakan untuk menambah tepi antara dua nod Tepi ini dan tepi lain adalah dua arah. Kaedah depthFirstSearch menggunakan tindanan untuk melaksanakan algoritma carian depth-first. Mula-mula, nod permulaan ditolak ke tindanan dan ditandakan sebagai dilawati. Kemudian, nod semasa muncul dari tindanan, nilai nod adalah output, dan nod jiran yang tidak dilawati ditolak ke tindanan dan ditandakan sebagai dilawati. Ulangi proses ini sehingga timbunan kosong.
Berikut ialah contoh penggunaan:
$graph = new Graph(); $graph->addNode("A"); $graph->addNode("B"); $graph->addNode("C"); $graph->addNode("D"); $graph->addNode("E"); $graph->addEdge("A", "B"); $graph->addEdge("A", "C"); $graph->addEdge("B", "D"); $graph->addEdge("C", "E"); echo "Depth First Search: "; $graph->depthFirstSearch($graph->getNode("A"));
Outputnya ialah: A B D C E
Kami mencipta graf dan menambah beberapa nod dan tepi. Kemudian, panggil kaedah depthFirstSearch untuk melakukan carian depth-first, bermula dari nod "A".
Di atas ialah contoh kod cara menggunakan PHP untuk menulis algoritma carian pertama mendalam untuk graf. Carian depth-first ialah algoritma traversal graf yang berkuasa yang sangat berguna untuk menyelesaikan beberapa masalah berkaitan graf.
Atas ialah kandungan terperinci Bagaimana untuk menulis algoritma carian mendalam-pertama untuk graf menggunakan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini akan menerangkan secara terperinci bagaimana PHP memformat baris ke dalam CSV dan menulis penunjuk fail saya rasa ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Format baris ke CSV dan tulis ke penuding fail Langkah 1: Buka penuding fail $file=fopen("path/to/file.csv","w"); kepada rentetan CSV. Fungsi ini menerima parameter berikut: $fail: penuding fail $medan: medan CSV sebagai tatasusunan $pembatas: pembatas medan (pilihan) $kepungan: petikan medan (

Artikel ini akan menerangkan secara terperinci tentang menukar umask semasa dalam PHP Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Gambaran keseluruhan PHP yang menukar umask semasa umask ialah fungsi php yang digunakan untuk menetapkan kebenaran fail lalai untuk fail dan direktori yang baru dibuat. Ia menerima satu hujah, iaitu nombor perlapanan yang mewakili kebenaran untuk menyekat. Sebagai contoh, untuk menghalang kebenaran menulis pada fail yang baru dibuat, anda akan menggunakan 002. Kaedah menukar umask Terdapat dua cara untuk menukar umask semasa dalam PHP: Menggunakan fungsi umask(): Fungsi umask() menukar secara langsung umask semasa. Sintaksnya ialah: intumas

Artikel ini akan menerangkan secara terperinci cara membuat fail dengan nama fail yang unik dalam PHP Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Mencipta fail dengan nama fail unik dalam PHP Pengenalan Mencipta fail dengan nama fail unik dalam PHP adalah penting untuk mengatur dan mengurus sistem fail anda. Nama fail yang unik memastikan bahawa fail sedia ada tidak ditimpa dan menjadikannya lebih mudah untuk mencari dan mendapatkan semula fail tertentu. Panduan ini akan merangkumi beberapa cara untuk menjana nama fail unik dalam PHP. Kaedah 1: Gunakan fungsi uniqid() Fungsi uniqid() menjana rentetan unik berdasarkan masa semasa dan mikrosaat. Rentetan ini boleh digunakan sebagai asas untuk nama fail.

Artikel ini akan menerangkan secara terperinci tentang PHP mengira cincangan fail MD5. Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. PHP mengira cincangan MD5 bagi fail MD5 (MessageDigest5) ialah algoritma penyulitan sehala yang menukarkan mesej dengan panjang sewenang-wenangnya kepada nilai cincang 128-bit panjang tetap. Ia digunakan secara meluas untuk memastikan integriti fail, mengesahkan ketulenan data dan mencipta tandatangan digital. Mengira cincang MD5 fail dalam PHP PHP menyediakan berbilang kaedah untuk mengira cincang MD5 bagi fail: Gunakan fungsi md5_file() Fungsi md5_file() mengira secara langsung nilai cincang MD5 bagi fail dan mengembalikan 32 aksara.

Artikel ini akan menerangkan secara terperinci pengekodan digital mesej ralat yang dikembalikan oleh PHP dalam operasi Mysql sebelumnya. Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan . Menggunakan PHP untuk mengembalikan maklumat ralat MySQL Pengekodan Berangka Pengenalan Semasa memproses pertanyaan mysql, anda mungkin menghadapi ralat. Untuk mengendalikan ralat ini dengan berkesan, adalah penting untuk memahami pengekodan berangka mesej ralat. Artikel ini akan membimbing anda menggunakan php untuk mendapatkan pengekodan berangka mesej ralat Mysql. Kaedah mendapatkan pengekodan berangka maklumat ralat 1. mysqli_errno() Fungsi mysqli_errno() mengembalikan nombor ralat terkini sambungan MySQL semasa. Sintaksnya adalah seperti berikut: $erro

Artikel ini akan menerangkan secara terperinci bagaimana PHP memotong fail mengikut panjang tertentu Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Pengenalan kepada pemangkasan fail PHP Fungsi file_put_contents() dalam PHP boleh digunakan untuk memotong fail pada panjang yang ditentukan. Pemangkasan bermaksud mengalih keluar sebahagian daripada hujung fail, dengan itu memendekkan panjang fail. Syntax file_put_contents($filename,$data,SEEK_SET,$offset);$filename: laluan fail yang akan dipotong. $data: Rentetan kosong untuk ditulis pada fail. SEEK_SET: ditetapkan sebagai permulaan fail

Artikel ini akan menerangkan secara terperinci bagaimana PHP mengembalikan tatasusunan selepas membalikkan nilai utama Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. PHP key value flip Array key value flip ialah operasi pada tatasusunan yang menukar kunci dan nilai dalam tatasusunan untuk menjana tatasusunan baharu dengan kunci asal sebagai nilai dan nilai asal sebagai kunci. Kaedah pelaksanaan Dalam PHP, anda boleh melakukan pembalik nilai kunci tatasusunan melalui kaedah berikut: fungsi array_flip(): Fungsi array_flip() digunakan khas untuk operasi flip nilai kunci. Ia menerima tatasusunan sebagai hujah dan mengembalikan tatasusunan baharu dengan kunci dan nilai ditukar. $original_array=[

Artikel ini akan menerangkan secara terperinci tentang mewujudkan sambungan simbolik dalam PHP Editor berpendapat ia sangat praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Pengenalan kepada mewujudkan pautan simbolik dalam PHP Pautan simbolik ialah jenis fail khas yang menunjuk ke fail atau direktori lain. Apabila pautan simbolik diakses, sistem secara automatik mengubah hala ke fail atau direktori sasaran seolah-olah mengakses fail atau direktori asal secara langsung. Dalam PHP, anda boleh menggunakan fungsi symlink() untuk membuat pautan simbolik. Symlink sintaks(string$target,string$link) di mana: $target: Laluan ke fail atau direktori sasaran untuk dipautkan. $link: Laluan pautan simbolik. ginseng
