cari
Rumahpembangunan bahagian belakangmasalah PHPMari kita bincangkan tentang kaedah pelaksanaan khusus pengisihan berbilang tatasusunan dalam PHP

Dalam PHP, tatasusunan ialah jenis data yang sangat biasa digunakan, dan dalam pembangunan sebenar, kita selalunya perlu mengisih tatasusunan. PHP menyediakan pelbagai algoritma pengisihan dan fungsi, yang boleh menjadikan operasi pengisihan sangat mudah dan cekap. Artikel ini akan memperkenalkan kaedah pelaksanaan khusus pengisihan berbilang tatasusunan dalam PHP.

I. Pengisihan tatasusunan satu dimensi

PHP menyediakan pelbagai algoritma dan fungsi pengisihan, yang boleh menjadikan operasi pengisihan mudah dan cekap. Antaranya, fungsi yang paling biasa digunakan ialah sort(), rsort(), asort(), arsort(), ksort(), krsort(), yang digunakan untuk mengisih tatasusunan pelbagai jenis.

  1. sort() dan rsort()

fungsi sort() dan rsort() digunakan untuk mengisih tatasusunan satu dimensi dalam tertib menaik (dari kecil ke besar) dan tertib menurun (daripada Terbesar kepada Terkecil) diisih. Fungsi sort() mengisih unsur dalam tertib menaik, dan fungsi rsort() mengisih unsur dalam tertib menurun.

Berikut ialah contoh menggunakan fungsi sort() untuk mengisih tatasusunan satu dimensi dalam tertib menaik:

<?php $fruits = array("lemon", "orange", "banana", "apple");
sort($fruits);
print_r($fruits);
?>

Hasil keluaran:

Array
(
    [0] => apple
    [1] => banana
    [2] => lemon
    [3] => orange
)

Berikut ialah contoh penggunaan rsort Contoh () fungsi mengisih tatasusunan satu dimensi dalam tertib menurun:

<?php $fruits = array("lemon", "orange", "banana", "apple");
rsort($fruits);
print_r($fruits);
?>

Hasil keluaran:

Array
(
    [0] => orange
    [1] => lemon
    [2] => banana
    [3] => apple
)
  1. asort() dan arsort()

Fungsi asort() dan arsort() digunakan untuk mengisih tatasusunan satu dimensi dalam tertib menaik (dari kecil ke besar) dan tertib menurun (dari besar ke kecil). Tidak seperti sort() dan rsort(), fungsi asort() dan arsort() mengekalkan hubungan indeks tatasusunan tidak berubah.

Berikut ialah contoh menggunakan fungsi asort() untuk mengisih tatasusunan satu dimensi dalam tertib menaik:

<?php $age = array("Peter"=>35, "Ben"=>37, "Joe"=>43);
asort($age);
print_r($age);
?>

Hasil keluaran:

Array
(
    [Peter] => 35
    [Ben] => 37
    [Joe] => 43
)

Berikut ialah contoh penggunaan asort() Contoh () fungsi mengisih tatasusunan satu dimensi dalam tertib menurun:

<?php $age = array("Peter"=>35, "Ben"=>37, "Joe"=>43);
arsort($age);
print_r($age);
?>

Hasil keluaran:

Array
(
    [Joe] => 43
    [Ben] => 37
    [Peter] => 35
)
  1. ksort () dan krsort()

Fungsi ksort() dan krsort() digunakan untuk mengisih tatasusunan satu dimensi dalam tertib menaik (dari kecil ke besar) atau tertib menurun (dari besar ke kecil ) dengan kunci. Fungsi ksort() mengisih mengikut nilai kunci dalam tertib menaik, manakala fungsi krsort() mengisih mengikut nilai kunci dalam tertib menurun.

Berikut ialah contoh menggunakan fungsi ksort() untuk mengisih tatasusunan satu dimensi dalam tertib menaik mengikut kekunci:

<?php $age = array("Peter"=>35, "Ben"=>37, "Joe"=>43);
ksort($age);
print_r($age);
?>

Hasil keluaran:

Array
(
    [Ben] => 37
    [Joe] => 43
    [Peter] => 35
)

Berikut ialah Contoh penggunaan fungsi krsort() untuk mengisih tatasusunan satu dimensi dalam tertib menurun mengikut kekunci:

<?php $age = array("Peter"=>35, "Ben"=>37, "Joe"=>43);
krsort($age);
print_r($age);
?>

Hasil keluaran:

Array
(
    [Peter] => 35
    [Joe] => 43
    [Ben] => 37
)

II. Isih tatasusunan berbilang dimensi

Untuk pengisihan tatasusunan berbilang dimensi, jika kita mengisih mengikut elemen tatasusunan dimensi pertama, kita boleh menggunakan empat fungsi sort(), rsort(), asort(), dan arsort(). Tetapi jika kita perlu mengisih mengikut kekunci lain tatasusunan berbilang dimensi, kita perlu menggunakan fungsi usort().

Fungsi usort() membolehkan kami menyesuaikan fungsi pengisihan untuk memenuhi pelbagai keperluan pengisihan kami. Apabila kami menyesuaikan fungsi pengisihan, kami menerima dua parameter, yang merujuk kepada dua elemen untuk dibandingkan. Apabila hasil perbandingan kedua-dua elemen ini kurang daripada 0, letakkan $elem1 sebelum $elem2, jika tidak letakkan $elem1 selepas $elem2.

Berikut ialah contoh menggunakan fungsi usort() untuk mengisih tatasusunan berbilang dimensi:

<?php $cars = array(
    array("Volvo",22,18),
    array("BMW",15,13),
    array("Saab",5,2),
    array("Land Rover",17,15)
);

function my_sort($a,$b)
{
    if ($a[0] == $b[0]) return 0;
    return ($a[0] < $b[0]) ? -1 : 1;
}

usort($cars, "my_sort");

foreach ($cars as $car) {
    echo $car[0] . " " . $car[1] . " " . $car[2] . "<br>";
}
?>

Hasil keluaran:

BMW 15 13
Land Rover 17 15
Saab 5 2
Volvo 22 18

Dalam perkara di atas contoh, kami Mentakrifkan fungsi my_sort() yang membandingkan elemen pertama tatasusunan. Kemudian panggil fungsi usort() dan hantar tatasusunan berbilang dimensi untuk diisih dan nama fungsi isihan tersuai kepada fungsi usort(). Selepas pengisihan selesai, kami menggunakan penyataan foreach untuk melintasi hasil yang diisih.

Ringkasnya, PHP menyediakan pelbagai algoritma pengisihan dan fungsi untuk memenuhi pelbagai keperluan pengisihan kami. Sama ada tatasusunan satu dimensi atau tatasusunan berbilang dimensi, PHP menyediakan fungsi pengisihan yang berbeza untuk beroperasi, membolehkan kami mengisih tatasusunan dengan mudah dan mudah.

Atas ialah kandungan terperinci Mari kita bincangkan tentang kaedah pelaksanaan khusus pengisihan berbilang tatasusunan dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Apakah amalan terbaik untuk deduplikasi tatasusunan phpApakah amalan terbaik untuk deduplikasi tatasusunan phpMar 03, 2025 pm 04:41 PM

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama?Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama?Mar 03, 2025 pm 04:51 PM

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi?Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi?Mar 03, 2025 pm 04:47 PM

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP?Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP?Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik?Apakah piawaian pengekodan PHP terkini dan amalan terbaik?Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan phpApakah teknik pengoptimuman untuk deduplikasi tatasusunan phpMar 03, 2025 pm 04:50 PM

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Bagaimana saya bekerja dengan sambungan php dan pecl?Bagaimana saya bekerja dengan sambungan php dan pecl?Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP?Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP?Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

See all articles

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.

Alat panas

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa