Rumah pembangunan bahagian belakang masalah PHP Cari nilai maksimum tatasusunan dua dimensi dalam php

Cari nilai maksimum tatasusunan dua dimensi dalam php

May 05, 2023 pm 09:16 PM

Dalam tatasusunan dua dimensi PHP, kita boleh menggunakan pelbagai kaedah untuk mencari nilai maksimum tatasusunan dua dimensi. Dalam artikel ini, tiga kaedah akan diperkenalkan untuk mencapai keperluan ini: kaedah pertama menggunakan lelaran gelung, kaedah dua menggunakan rekursi dan kaedah tiga menggunakan fungsi terbina dalam PHP.

Kaedah 1: Gunakan lelaran gelung

Kaedah menggunakan lelaran gelung ialah salah satu kaedah yang paling biasa digunakan. Kita boleh menggelungkan keseluruhan tatasusunan dua dimensi dan menggunakan pembolehubah untuk menyimpan nilai maksimum yang ditemui pada masa ini Jika nilai yang lebih besar daripada nilai maksimum semasa ditemui, nilai maksimum semasa dikemas kini kepada nilai baharu.

Kod untuk kaedah ini adalah seperti berikut:

function findMaxValue($array)
{
    $maxValue = $array[0][0]; // 首先假设最大值为数组首元素
    foreach ($array as $value) {
        foreach ($value as $num) {
            if ($num > $maxValue) { // 发现更大的值,就更新最大值
                $maxValue = $num;
            }
        }
    }
    return $maxValue; // 返回最大值
}
Salin selepas log masuk

Contoh penggunaan:

$array = array(
    array(1, 2, 3),
    array(4, 5, 6),
    array(7, 8, 9)
);

echo findMaxValue($array); // 输出 9
Salin selepas log masuk

Kaedah 2: Gunakan rekursi

Menggunakan rekursi boleh memproses kaedah kedua lebih mudah Tatasusunan dimensi, terutamanya apabila tatasusunan tidak teratur, boleh diselesaikan dengan lebih baik melalui pengulangan.

Untuk menggunakan kaedah rekursif, anda perlu menulis fungsi rekursif. Tugas fungsi rekursif ini ialah memanggil dirinya secara rekursif jika elemen semasa ialah tatasusunan, jika tidak mengembalikan elemen semasa. Hasil daripada fungsi rekursif ialah nilai maksimum antara semua elemen. Setiap lelaran, kita perlu membandingkan saiz elemen semasa dengan nilai maksimum semasa dan mengemas kini nilai maksimum.

Kod untuk kaedah ini adalah seperti berikut:

function findMaxValue($array, $maxValue = null)
{
    if (!is_array($array)) {
        if ($maxValue === null) { // 如果还没有找到最大值
            return $array;
        }
        return max($array, $maxValue); // 和当前最大值比较
    }
    foreach ($array as $value) {
        $maxValue = findMaxValue($value, $maxValue); // 递归调用自身
    }
    return $maxValue; // 返回最大值
}
Salin selepas log masuk

Contoh penggunaan:

$array = array(
    array(1, 2, 3),
    array(4, array(5, 9, 6), 7),
    array(10, 11, 12)
);

echo findMaxValue($array); // 输出 12
Salin selepas log masuk
Salin selepas log masuk

Kaedah 3: Gunakan fungsi terbina dalam PHP

Kaedah ini menggunakan Fungsi terbina dalam PHP max () dan call_user_func_array() untuk mencari nilai maksimum dalam tatasusunan dua dimensi.

Kami akan menggunakan ciri yang dipanggil "rujukan", yang akan dibincangkan dalam contoh berikut.

Kod untuk kaedah ini adalah seperti berikut:

function findMaxValue($array)
{
    return max(call_user_func_array('array_merge', $array)); // 返回最大值
}
Salin selepas log masuk

Contoh penggunaan:

$array = array(
    array(1, 2, 3),
    array(4, array(5, 9, 6), 7),
    array(10, 11, 12)
);

echo findMaxValue($array); // 输出 12
Salin selepas log masuk
Salin selepas log masuk

Kaedah ini agak mudah, tetapi ia tidak mudah difahami. Prinsipnya adalah seperti berikut:

  • Gunakan array_merge() untuk menukar tatasusunan dua dimensi kepada tatasusunan satu dimensi. Fungsi array_merge() yang kami hantar ke call_user_func_array() menggabungkan semua tatasusunan yang bersarang dalam tatasusunan 2D ke dalam tatasusunan tunggal.
  • Gunakan call_user_func_array() untuk memanggil fungsi max() dan hantarkan nilai dalam tatasusunan.

Menggunakan kaedah ini boleh meningkatkan kecekapan apabila tatasusunan panjang, kerana ia hanya memerlukan satu lelaran elemen dalam tatasusunan dan bukannya lelaran berganda.

Kesimpulan

Di atas adalah tiga kaedah untuk mencari nilai maksimum tatasusunan dua dimensi Dalam situasi yang berbeza, kaedah yang berbeza boleh digunakan untuk mencapai prestasi terbaik. Adalah disyorkan untuk menggunakan kaedah satu apabila melakukan pengaturcaraan pembangunan asas, kerana kaedah ini boleh difahami dengan baik dan mudah dibaca dan diselenggara. Dan jika anda mempunyai sekeping kod yang perlu mencari nilai maksimum tatasusunan dua dimensi dengan struktur bersarang yang kompleks, anda harus menggunakan fungsi rekursif kerana ia lebih mudah dan jelas. Menggunakan fungsi terbina dalam PHP, anda boleh mendapatkan hasil dengan cepat, terutamanya apabila sejumlah besar data perlu diproses, kecekapan adalah jelas.

Atas ialah kandungan terperinci Cari nilai maksimum tatasusunan dua dimensi 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

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)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 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)

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.

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.

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.

Apakah tujuan penyataan yang disediakan dalam PHP? Apakah tujuan penyataan yang disediakan dalam PHP? Mar 20, 2025 pm 04:47 PM

Kenyataan yang disediakan dalam PHP meningkatkan keselamatan pangkalan data dan kecekapan dengan mencegah suntikan SQL dan meningkatkan prestasi pertanyaan melalui kompilasi dan penggunaan semula.

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

Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Mar 20, 2025 pm 04:57 PM

Artikel membincangkan mendapatkan data dari pangkalan data menggunakan PHP, meliputi langkah, langkah keselamatan, teknik pengoptimuman, dan kesilapan umum dengan penyelesaian.

See all articles