2658. Jumlah maksimum ikan dalam grid
Kesukaran: Medium
Topik: array, carian kedalaman pertama, carian lebar pertama, mencari kesatuan, matriks
anda diberi grid matriks 2D 0-indexed saiz m x n, di mana (r, c) mewakili:
- A
- sel jika grid [r] [c] = 0, atau
A
air sel yang mengandungi grid [r] [c] ikan, jika grid [r] [c] & gt; 0. - Fisher boleh bermula di mana -mana air
menangkap semua ikan di sel (r, c), atau
- bergerak ke mana -mana sel
- sel .
- kembali maksimum
. sel yang bersebelahan sel (r, c), adalah salah satu sel (r, c 1), (r, c - 1), (r 1, c) atau (r - 1, c) Jika wujud.
Contoh 1:
input:
output:
- Penjelasan: Fisher boleh bermula pada sel (1,3) dan mengumpul 3 ikan, kemudian pindah ke sel (2,3) dan mengumpul 4 ikan.
- Contoh 2:
-
input:
1
- Penjelasan:
- Fisher boleh bermula pada sel (0,0) atau (3,3) dan mengumpul satu ikan.
- Kekangan:
- m == grid.length n == grid [i] .length
0 & lt; = grid [i] [j] & lt; = 10
- Petunjuk:
- Jalankan DFS dari setiap sel bukan sifar.
- Setiap kali anda memilih sel untuk bermula dari, tambahkan bilangan ikan yang terkandung dalam sel yang anda lawati.
Penyelesaian:
- Masalahnya adalah untuk mencari bilangan maksimum ikan yang dapat ditangkap oleh nelayan dengan memulakan di mana -mana sel air dalam grid. Fisher boleh menangkap ikan di sel semasa dan bergerak ke mana -mana sel air bersebelahan (ke atas, ke bawah, kiri, atau kanan) berulang kali.
-
Mata Utama:
- grid mengandungi sel yang sama ada tanah (nilai 0) atau air (nilai & gt; 0).
- Fisher hanya boleh bergerak ke sel air bersebelahan.
- Objektifnya adalah untuk mencari bilangan maksimum ikan yang boleh dikumpulkan, bermula dari sel air yang terbaik.
Pendekatan:
- Gunakan carian kedalaman-pertama (DFS) untuk meneroka semua laluan yang mungkin bermula dari setiap sel air.
- Bagi setiap sel air yang tidak disahkan, jalankan DFS untuk mengira jumlah ikan dalam komponen yang disambungkan.
- menjejaki ikan maksimum yang dikumpulkan dari mana -mana komponen yang disambungkan.
Merancang:
- memulakan array 2D yang dikunjungi untuk mengesan sama ada sel telah diterokai.
- meleleh melalui setiap sel dalam grid.
- Jika sel mengandungi air dan tidak dikunjungi:
- Jalankan DFS bermula dari sel itu.
- mengumpulkan jumlah ikan dalam sel air yang disambungkan.
- Kemas kini ikan maksimum yang dikumpulkan setakat ini.
- Kembalikan kiraan ikan maksimum selepas meneroka semua sel.
mari kita melaksanakan penyelesaian ini dalam php: 2658. Bilangan maksimum ikan dalam grid
<?php /** * @param Integer[][] $grid * @return Integer */ function findMaxFish($grid) { ... ... ... /** * go to ./solution.php */ } /** * Helper function for DFS * @param $r * @param $c * @param $grid * @param $visited * @param $rows * @param $cols * @param $directions * @return array|bool|int|int[]|mixed|null */ function dfs($r, $c, &$grid, &$visited, $rows, $cols, $directions) { ... ... ... /** * go to ./solution.php */ } // Example 1 grid = [[0,2,1,0],[4,0,0,3],[1,0,0,4],[0,3,2,0]]; echo getMaxFish($grid); // Output: 7 // Example 2 $grid = [[1,0,0,0],[0,0,0,0],[0,0,0,0],[0,0,0,1]]; echo getMaxFish($grid); // Output: 1 ?>
Penjelasan:
Pelaksanaan DFS:
- untuk setiap sel air (r, c), rekursif meneroka jirannya jika mereka:
- di dalam sempadan grid.
- Unvisited.
- sel air (nilai & gt; 0).
- mengumpul kiraan ikan semasa rekursi.
Langkah:
- Mula dari sel air dan tandakannya seperti yang dikunjungi.
- berulang -ulang melawat jirannya yang sah, menambah kiraan ikan.
- Kembalikan jumlah kiraan ikan untuk komponen yang disambungkan.
Contoh Walkthrough:
Contoh Input:
$grid = [ [0, 2, 1, 0], [4, 0, 0, 3], [1, 0, 0, 4], [0, 3, 2, 0] ];
Pelaksanaan:
- mulakan pada (1, 3) (nilai = 3). Jalankan DFS:
- (1, 3) → (2, 3) (nilai = 4).
- total ikan = 3 4 = 7.
- meneroka sel air lain, tetapi tidak ada komponen yang disambungkan mempunyai jumlah ikan yang lebih tinggi.
- output: 7.
Kerumitan masa:
- dfs traversal: Setiap sel dikunjungi sekali → o (m × n).
- kerumitan keseluruhan: (m × n), di mana m dan n adalah dimensi grid.
Output untuk contoh:
- Contoh 1: 7
- Contoh 2: 1
Penyelesaian dengan cekap menggunakan DFS untuk meneroka komponen sel -sel air yang disambungkan dan mengira ikan maksimum yang dapat ditangkap oleh seorang nelayan bermula dari mana -mana sel air. Pendekatan ini memastikan penerokaan optimum dan berfungsi dengan baik untuk kekangan yang diberikan.
Pautan kenalan
Jika anda mendapati siri ini membantu, sila pertimbangkan untuk memberikan repositori bintang di GitHub atau berkongsi jawatan di rangkaian sosial kegemaran anda? Sokongan anda sangat bermakna bagi saya!
Jika anda mahukan kandungan yang lebih berguna seperti ini, jangan ragu untuk mengikuti saya:
- github
Atas ialah kandungan terperinci Jumlah maksimum ikan dalam grid. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Dalam PHP, sifat sesuai untuk situasi di mana penggunaan semula kaedah diperlukan tetapi tidak sesuai untuk warisan. 1) Ciri membolehkan kaedah multiplexing dalam kelas untuk mengelakkan pelbagai kerumitan warisan. 2) Apabila menggunakan sifat, anda perlu memberi perhatian kepada konflik kaedah, yang dapat diselesaikan melalui alternatif dan sebagai kata kunci. 3) Tua yang berlebihan harus dielakkan dan tanggungjawab tunggalnya harus dikekalkan untuk mengoptimumkan prestasi dan meningkatkan pemeliharaan kod.

Kontena Suntikan Ketergantungan (DIC) adalah alat yang menguruskan dan menyediakan kebergantungan objek untuk digunakan dalam projek PHP. Manfaat utama DIC termasuk: 1. Decoupling, membuat komponen bebas, dan kod itu mudah dikekalkan dan diuji; 2. Fleksibiliti, mudah untuk menggantikan atau mengubah suai kebergantungan; 3. Keseluruhan, mudah untuk menyuntik objek mengejek untuk ujian unit.

SplfixedArray adalah pelbagai saiz tetap dalam PHP, sesuai untuk senario di mana prestasi tinggi dan penggunaan memori yang rendah diperlukan. 1) Ia perlu menentukan saiz apabila membuat untuk mengelakkan overhead yang disebabkan oleh pelarasan dinamik. 2) Berdasarkan pelbagai bahasa C, secara langsung mengendalikan memori dan kelajuan akses cepat. 3) Sesuai untuk pemprosesan data berskala besar dan persekitaran sensitif memori, tetapi ia perlu digunakan dengan berhati-hati kerana saiznya tetap.

PHP mengendalikan fail muat naik melalui pembolehubah fail $ \ _. Kaedah untuk memastikan keselamatan termasuk: 1. Semak kesilapan muat naik, 2. Sahkan jenis dan saiz fail, 3. Mencegah penindasan fail, 4. Pindahkan fail ke lokasi storan tetap.

Dalam JavaScript, anda boleh menggunakan NullcoalescingOperator (??) dan NullcoalescingAssignmentOperator (?? =). 1.? Menerapkan semula operan pertama yang tidak berselisih atau tidak ditentukan. 2.?? Pengendali ini memudahkan logik kod, meningkatkan kebolehbacaan dan prestasi.

CSP adalah penting kerana ia boleh menghalang serangan XSS dan mengehadkan pemuatan sumber, meningkatkan keselamatan laman web. 1.CSP adalah sebahagian daripada tajuk tindak balas HTTP, mengehadkan tingkah laku berniat jahat melalui dasar yang ketat. 2. Penggunaan asas adalah untuk hanya membenarkan sumber pemuatan dari asal yang sama. 3. Penggunaan lanjutan boleh menetapkan lebih banyak strategi halus, seperti membenarkan nama domain tertentu untuk memuat skrip dan gaya. 4. Gunakan header-surcury-policy-report-only header untuk debug dan mengoptimumkan dasar CSP.

Kaedah permintaan HTTP termasuk GET, POST, PUT dan DELETE, yang digunakan untuk mendapatkan, menghantar, mengemas kini dan memadam sumber masing -masing. 1. Kaedah GET digunakan untuk mendapatkan sumber dan sesuai untuk operasi membaca. 2. Kaedah Pos digunakan untuk menyerahkan data dan sering digunakan untuk membuat sumber baru. 3. Kaedah Put digunakan untuk mengemas kini sumber dan sesuai untuk kemas kini lengkap. 4. Kaedah Padam digunakan untuk memadam sumber dan sesuai untuk operasi penghapusan.

HTTPS adalah protokol yang menambah lapisan keselamatan berdasarkan HTTP, yang terutamanya melindungi privasi pengguna dan keselamatan data melalui data yang disulitkan. Prinsip kerjanya termasuk jabat tangan TLS, pengesahan sijil dan komunikasi yang disulitkan. Apabila melaksanakan HTTPS, anda perlu memberi perhatian kepada pengurusan sijil, kesan prestasi dan isu kandungan campuran.


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

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan