Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk mencari nombor kedua terbesar dalam tatasusunan dalam php

Bagaimana untuk mencari nombor kedua terbesar dalam tatasusunan dalam php

May 11, 2023 am 09:46 AM

Sebagai bahasa pembangunan yang popular, PHP mempunyai banyak sintaks dan fungsi yang berkuasa untuk menyokong kerja pembangun. Dari segi operasi tatasusunan, PHP juga menyediakan pelbagai kaedah untuk menyelesaikan pelbagai jenis masalah. Antaranya, mencari nombor kedua terbesar dalam tatasusunan juga merupakan tugas biasa. Dalam artikel ini, kami akan memperkenalkan beberapa fungsi dan algoritma PHP untuk membantu anda mencari nombor kedua terbesar dalam tatasusunan dengan cepat.

Pertama, kita boleh menggunakan fungsi terbina dalam PHP untuk mendapatkan nombor terbesar dan nombor terkecil dalam tatasusunan. Fungsi ini masing-masing adalah max() dan min().

Sebagai contoh, katakan kita mempunyai tatasusunan nombor:

$arr = [3, 1, 7, 4, 5];
Salin selepas log masuk

Kita boleh mendapatkan nilai maksimum seperti ini:

$max = max($arr);
Salin selepas log masuk

Ini akan mengembalikan 7. Begitu juga, kita boleh mendapatkan nilai minimum seperti ini:

$min = min($arr);
Salin selepas log masuk

Ini akan mengembalikan 1. Dengan data ini, kita boleh menggunakan gelung untuk mencari nombor terbesar seterusnya:

$secondMax = $min;
foreach ($arr as $number) {
   if ($number > $secondMax && $number < $max) {
      $secondMax = $number;
   }
}
Salin selepas log masuk

Gelung ini akan menyemak setiap nombor dalam tatasusunan satu demi satu, jika ia lebih besar daripada nombor kedua terbesar, tetapi kurang daripada terbesar Jika nombor itu lebih kecil, maka ia akan menjadi nombor kedua terbesar yang baharu. Apabila gelung berakhir, $secondMax akan mengandungi nombor kedua terbesar yang kami cari. Jika tiada nombor kedua terbesar dalam tatasusunan, $secondMax akan kekal pada nilai minimum, $min.

Semasa penyelesaian ini berfungsi, kerumitannya ialah O(n). Jika tatasusunan besar, ini boleh menjadikan program tidak cekap. Oleh itu, kita boleh menggunakan penyelesaian yang lebih cekap.

Penyelesaian kedua ialah menggunakan fungsi rsort() PHP untuk mengisih tatasusunan dalam susunan terbalik. Kemudian, kita boleh mendapatkan elemen kedua tatasusunan sebagai nombor kedua terbesar.

rsort($arr);
$secondMax = $arr[1];
Salin selepas log masuk

Kerumitan masa penyelesaian ini ialah O(nlogn), yang lebih pantas daripada penyelesaian pertama. Walau bagaimanapun, ia memerlukan pengisihan keseluruhan tatasusunan, jadi boleh menggunakan lebih banyak memori.

Penyelesaian ketiga ialah menggunakan fungsi array_unique() PHP untuk mengalih keluar elemen pendua, kemudian gunakan fungsi rsort() untuk mengisih tatasusunan dalam susunan terbalik, dan akhirnya dapatkan elemen kedua tatasusunan sebagai yang kedua terbesar nombor.

$arr = array_unique($arr);
rsort($arr);
$secondMax = $arr[1];
Salin selepas log masuk

Penyelesaian ini mengalih keluar elemen pendua untuk mengelakkan nombor sub-maksimum pendua. Memandangkan kerumitan masa ialah O(nlogn), ia serupa dengan penyelesaian kedua.

Ringkasnya, anda boleh menggunakan tiga kaedah di atas untuk mencari nombor kedua terbesar dalam tatasusunan. Antaranya, penyelesaian pertama adalah yang paling mudah, tetapi mungkin kurang cekap penyelesaian kedua memperoleh nilai sasaran dengan menyusun dalam urutan terbalik, tetapi memerlukan memori tambahan boleh memadamkan elemen pendua, tetapi kurang cekap Sama seperti yang kedua; penyelesaian dari segi penggunaan memori. Anda boleh memilih penyelesaian yang paling sesuai dengan anda berdasarkan senario sebenar anda.

Atas ialah kandungan terperinci Bagaimana untuk mencari nombor kedua terbesar dalam tatasusunan dalam 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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

Pengesahan Input PHP: Amalan Terbaik. Pengesahan Input PHP: Amalan Terbaik. Mar 26, 2025 pm 04:17 PM

Artikel membincangkan amalan terbaik untuk pengesahan input PHP untuk meningkatkan keselamatan, memberi tumpuan kepada teknik seperti menggunakan fungsi terbina dalam, pendekatan putih, dan pengesahan sisi pelayan.

PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. Mar 25, 2025 pm 03:05 PM

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

See all articles