


php mengecualikan elemen semasa daripada tatasusunan produk
PHP ialah bahasa skrip yang digunakan secara meluas yang biasa digunakan dalam bidang pembangunan web. Dalam PHP, kita sering menghadapi situasi di mana tatasusunan perlu diproses. Sebagai contoh, diberikan tatasusunan, ia diperlukan untuk mengira hasil darab unsur yang tinggal selepas mengalih keluar unsur semasa. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan tatasusunan produk selepas mengalih keluar elemen semasa.
1. Idea asal:
Kita boleh menggunakan dua gelung untuk mencapai keperluan ini:
- Gelung luar merentasi setiap elemen
- Bahagian dalam gelung mengira hasil bagi elemen selain daripada elemen semasa yang dilalui
Walau bagaimanapun, kerumitan masa kaedah ini ialah O(n^2) Apabila terdapat terlalu banyak elemen tatasusunan, masa pelaksanaan program akan meningkat dengan ketara. Oleh itu, kita perlu mengubah pemikiran kita untuk meningkatkan kecekapan algoritma.
2. Idea Pengoptimuman:
Kami mula-mula boleh mengira hasil darab keseluruhan tatasusunan, dan kemudian membahagikan hasil darab keseluruhan tatasusunan dengan elemen semasa berdasarkan elemen semasa untuk mendapatkan produk selepas mengeluarkan elemen semasa.
Walau bagaimanapun, kaedah ini akan menyebabkan masalah apabila elemen semasa ialah 0, kerana pembahagian dengan 0 tidak bermakna. Oleh itu, kita perlu mengendalikan kes di mana elemen semasa ialah 0.
3. Kod lengkap:
Kod PHP lengkap diberikan di bawah:
function productExceptSelf($nums) { $length = count($nums); if ($length == 0) { return array(); } elseif ($length == 1) { return array(0); } $prod = 1; $zeroCount = 0; for ($i = 0; $i < $length; $i++) { if ($nums[$i] == 0) { $zeroCount++; if ($zeroCount > 1) { return array_fill(0, $length, 0); } continue; } $prod *= $nums[$i]; } $res = array(); for ($i = 0; $i < $length; $i++) { if ($zeroCount == 1 && $nums[$i] != 0) { $res[] = 0; continue; } if ($zeroCount > 1) { $res[] = 0; continue; } $res[] = $nums[$i] == 0 ? $prod : $prod / $nums[$i]; } return $res; }
4 Analisis kod:
Kod di atas menggunakan idea berikut : Mula-mula, imbas keseluruhan tatasusunan dan kira hasil darab unsur bukan sifar dalam tatasusunan. Pada masa yang sama, rekodkan bilangan 0s dalam tatasusunan. Kedua, keseluruhan tatasusunan diimbas, dan untuk setiap elemen, hasil akhir dikira berdasarkan jumlah produk di atas dan bilangan 0s.
Antaranya, pemprosesan khas diterima pakai apabila elemen semasa ialah 0. Jika bilangan 0s dalam tatasusunan lebih besar daripada 1, tatasusunan di mana semua elemen adalah 0 akan dikembalikan secara langsung, jika tidak, hasil darab unsur semasa ialah 0.
5. Kes ujian:
Berikut ialah beberapa set data ujian:
$nums = [1, 2, 3, 4];
gema meletup (" ,", productExceptSelf($nums)); // Output "24,12,8,6"
$nums = [0, 2, 3, 4];
echo implode(" ," , productExceptSelf($nums)); // Output "24,0,0,0"
$nums = [1, 0, 3, 4];
echo implode("," , productExceptSelf ($nums)); // Output "0,12,0,0"
$nums = [1, 0, 3, 0];
echo implode(",", productExceptSelf ($ nums)); // Output "0,0,0,0"
6. Ringkasan:
Artikel ini memperkenalkan cara menggunakan PHP untuk melaksanakan tatasusunan produk selepas mengalih keluar arus. unsur. Melalui algoritma pengoptimuman, kerumitan masa program dapat dikurangkan dengan berkesan dan kecekapan pelaksanaan program dapat dipertingkatkan. Dalam pembangunan sebenar, kita harus memilih algoritma optimum untuk memproses tatasusunan mengikut situasi tertentu.
Atas ialah kandungan terperinci php mengecualikan elemen semasa daripada tatasusunan produk. 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 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

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

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,

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

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.

Artikel ini meneroka strategi untuk kekal semasa dalam ekosistem PHP. Ia menekankan penggunaan saluran rasmi, forum komuniti, persidangan, dan sumbangan sumber terbuka. Penulis menyoroti sumber terbaik untuk mempelajari ciri -ciri baru dan a

Artikel ini menangani pengoptimuman memori PHP. IT memperincikan teknik seperti menggunakan struktur data yang sesuai, mengelakkan penciptaan objek yang tidak perlu, dan menggunakan algoritma yang cekap. Sumber kebocoran memori biasa (mis., Sambungan yang tidak terkawal, global v

Artikel ini meneroka pelaksanaan tugas tak segerak dalam PHP untuk meningkatkan respons aplikasi web. Ia memperincikan kaedah seperti beratur mesej, rangka kerja asynchronous (reactphp, swoole), dan proses latar belakang, menekankan amalan terbaik untuk kecekapan
