Rumah pembangunan bahagian belakang tutorial php Bilangan Operasi Minimum untuk Mengalihkan Semua Bola ke Setiap Kotak

Bilangan Operasi Minimum untuk Mengalihkan Semua Bola ke Setiap Kotak

Jan 06, 2025 pm 10:34 PM

Minimum Number of Operations to Move All Balls to Each Box

1769. Bilangan Operasi Minimum untuk Mengalihkan Semua Bola ke Setiap Kotak

Kesukaran: Sederhana

Topik: Tatasusunan, Rentetan, Jumlah Awalan

Anda mempunyai n kotak. Anda diberi kotak rentetan binari dengan panjang n, dengan kotak[i] ialah '0' jika kotak ith kosong dan '1' jika mengandungi satu bola.

Dalam satu operasi, anda boleh memindahkan satu bola dari kotak ke kotak bersebelahan. Kotak i bersebelahan dengan kotak j jika abs(i - j) == 1. Ambil perhatian bahawa selepas berbuat demikian, mungkin terdapat lebih daripada satu bola dalam beberapa kotak.

Kembalikan jawapan tatasusunan saiz n, dengan jawapan[i] ialah minimum bilangan operasi yang diperlukan untuk memindahkan semua bola ke kotak ike.

Setiap jawapan[i] dikira dengan mengambil kira keadaan awal kotak.

Contoh 1:

  • Input: kotak = "110"
  • Output: [1,1,3]
  • Penjelasan: Jawapan bagi setiap kotak adalah seperti berikut:
    1. Kotak pertama: anda perlu mengalihkan satu bola dari kotak kedua ke kotak pertama dalam satu operasi.
    2. Kotak kedua: anda perlu memindahkan satu bola dari kotak pertama ke kotak kedua dalam satu operasi.
    3. Kotak ketiga: anda perlu memindahkan satu bola dari kotak pertama ke kotak ketiga dalam dua operasi dan memindahkan satu bola dari kotak kedua ke kotak ketiga dalam satu operasi.

Contoh 2:

  • Input: kotak = "001011"
  • Output: [11,8,5,4,3,4]

Kekangan:

  • n == kotak.panjang
  • 1 <= n <= 2000
  • kotak[i] sama ada '0' atau '1'.

Petunjuk:

  1. Jika anda ingin memindahkan bola dari kotak i ke kotak j, anda memerlukan pergerakan abs(i-j).
  2. Untuk mengalihkan semua bola ke beberapa kotak, anda boleh mengalihkannya satu demi satu.
  3. Untuk setiap kotak i, lelaran pada setiap bola dalam kotak j dan tambah abs(i-j) pada jawapan[i].

Penyelesaian:

Kami boleh menggunakan pendekatan jumlah awalan yang membolehkan kami mengira bilangan minimum operasi yang diperlukan untuk memindahkan semua bola ke setiap kotak tanpa mensimulasikan setiap operasi secara eksplisit.

Pemerhatian Utama:

  1. Bilangan pergerakan yang diperlukan untuk memindahkan bola dari kotak i ke kotak j hanyalah abs(i - j).
  2. Kita boleh mengira jumlah pergerakan untuk memindahkan semua bola ke kotak tertentu dengan memanfaatkan kedudukan bola dan jumlah operasi yang sedang berjalan.
  3. Dengan mengira pergerakan dari kiri ke kanan dan kanan ke kiri, kita boleh menentukan keputusan dalam dua hantaran.

Pendekatan:

  1. Hantaran Kiri-ke-Kanan: Dalam hantaran ini, kira bilangan pergerakan untuk membawa semua bola ke kotak semasa bermula dari kiri.
  2. Hantar Kanan ke Kiri: Dalam hantaran ini, kira bilangan pergerakan untuk membawa semua bola ke kotak semasa bermula dari kanan.
  3. Gabungkan keputusan kedua-dua pas untuk mendapatkan keputusan akhir bagi setiap kotak.

Langkah Penyelesaian:

  1. Mulakan dengan mengulangi rentetan kotak dan mengira bilangan bola di sebelah kiri dan di sebelah kanan setiap kotak.
  2. Semasa lelaran, hitung bilangan pergerakan yang diperlukan untuk membawa semua bola ke kotak semasa menggunakan kedua-dua maklumat kiri dan kanan.

Mari laksanakan penyelesaian ini dalam PHP: 1769. Bilangan Minimum Operasi untuk Mengalihkan Semua Bola ke Setiap Kotak

<?php
/**
 * @param String $boxes
 * @return Integer[]
 */
function minOperations($boxes) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example usage:
$boxes = "110";
print_r(minOperations($boxes)); // Output: [1,1,3]

$boxes = "001011";
print_r(minOperations($boxes)); // Output: [11,8,5,4,3,4]
?>




<h3>
  
  
  Penjelasan:
</h3>

<ol>
<li>
<strong>Hantar kiri ke kanan</strong>: Kami mengira jumlah bilangan operasi yang diperlukan untuk membawa semua bola dari sebelah kiri ke kotak semasa. Untuk setiap bola yang ditemui ('1'), kami mengemas kini jumlah bilangan pergerakan.</li>
<li>
<strong>Hantar kanan ke kiri</strong>: Sama seperti hantaran kiri ke kanan, tetapi kami mengira bilangan operasi untuk mengalihkan bola dari sebelah kanan ke kotak semasa.</li>
<li>Jumlah operasi untuk setiap kotak ialah jumlah pergerakan dari hantaran kiri dan kanan.</li>
</ol>

<h3>
  
  
  Contoh Panduan:
</h3>

<h4>
  
  
  Contoh 1:
</h4>



<pre class="brush:php;toolbar:false">$boxes = "110";
print_r(minOperations($boxes));
Salin selepas log masuk

Output:

Array
(
    [0] => 1
    [1] => 1
    [2] => 3
)
Salin selepas log masuk

Contoh 2:

$boxes = "001011";
print_r(minOperations($boxes));
Salin selepas log masuk

Output:

Array
(
    [0] => 11
    [1] => 8
    [2] => 5
    [3] => 4
    [4] => 3
    [5] => 4
)
Salin selepas log masuk

Kerumitan Masa:

  • Penyelesaian berjalan dalam masa O(n) kerana kami mengulangi rentetan kotak dua kali (sekali untuk hantaran kiri ke kanan dan sekali untuk hantaran kanan ke kiri).
  • Kerumitan ruang ialah O(n) kerana kami menyimpan tatasusunan jawapan untuk menyimpan hasilnya.

Penyelesaian ini mengira bilangan operasi minimum untuk setiap kotak dengan cekap menggunakan teknik jumlah awalan.

Pautan Kenalan

Jika anda mendapati siri ini membantu, sila pertimbangkan untuk memberi repositori bintang di GitHub atau berkongsi siaran pada rangkaian sosial kegemaran anda ?. Sokongan anda amat bermakna bagi saya!

Jika anda mahukan kandungan yang lebih berguna seperti ini, sila ikuti saya:

  • LinkedIn
  • GitHub

Atas ialah kandungan terperinci Bilangan Operasi Minimum untuk Mengalihkan Semua Bola ke Setiap Kotak. 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)

Topik panas

Tutorial Java
1657
14
Tutorial PHP
1257
29
Tutorial C#
1229
24
Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Jelaskan JSON Web Tokens (JWT) dan kes penggunaannya dalam PHP API. Apr 05, 2025 am 12:04 AM

JWT adalah standard terbuka berdasarkan JSON, yang digunakan untuk menghantar maklumat secara selamat antara pihak, terutamanya untuk pengesahan identiti dan pertukaran maklumat. 1. JWT terdiri daripada tiga bahagian: header, muatan dan tandatangan. 2. Prinsip kerja JWT termasuk tiga langkah: menjana JWT, mengesahkan JWT dan muatan parsing. 3. Apabila menggunakan JWT untuk pengesahan di PHP, JWT boleh dijana dan disahkan, dan peranan pengguna dan maklumat kebenaran boleh dimasukkan dalam penggunaan lanjutan. 4. Kesilapan umum termasuk kegagalan pengesahan tandatangan, tamat tempoh, dan muatan besar. Kemahiran penyahpepijatan termasuk menggunakan alat debugging dan pembalakan. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan algoritma tandatangan yang sesuai, menetapkan tempoh kesahihan dengan munasabah,

Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Bagaimanakah sesi merampas kerja dan bagaimana anda dapat mengurangkannya dalam PHP? Apr 06, 2025 am 12:02 AM

Sesi rampasan boleh dicapai melalui langkah -langkah berikut: 1. Dapatkan ID Sesi, 2. Gunakan ID Sesi, 3. Simpan sesi aktif. Kaedah untuk mengelakkan rampasan sesi dalam PHP termasuk: 1. Gunakan fungsi Sesi_Regenerate_ID () untuk menjana semula ID Sesi, 2. Data sesi stor melalui pangkalan data, 3.

Bagaimanakah anda mengendalikan pengecualian dengan berkesan dalam PHP (cuba, menangkap, akhirnya, membuang)? Bagaimanakah anda mengendalikan pengecualian dengan berkesan dalam PHP (cuba, menangkap, akhirnya, membuang)? Apr 05, 2025 am 12:03 AM

Dalam PHP, pengendalian pengecualian dicapai melalui percubaan, menangkap, akhirnya, dan membuang kata kunci. 1) blok percubaan mengelilingi kod yang boleh membuang pengecualian; 2) Blok tangkapan mengendalikan pengecualian; 3) Akhirnya Blok memastikan bahawa kod itu sentiasa dilaksanakan; 4) Lemparan digunakan untuk membuang pengecualian secara manual. Mekanisme ini membantu meningkatkan keteguhan dan mengekalkan kod anda.

Terangkan jenis ralat yang berbeza dalam PHP (notis, amaran, ralat maut, ralat parse). Terangkan jenis ralat yang berbeza dalam PHP (notis, amaran, ralat maut, ralat parse). Apr 08, 2025 am 12:03 AM

Terdapat empat jenis kesilapan utama dalam PHP: 1.Notice: yang paling sedikit, tidak akan mengganggu program, seperti mengakses pembolehubah yang tidak ditentukan; 2. Amaran: Serius daripada notis, tidak akan menamatkan program, seperti tidak mengandungi fail; 3. FatalError: Yang paling serius, akan menamatkan program ini, seperti tidak memanggil fungsi; 4. ParseError: Kesalahan sintaks, akan menghalang program daripada dilaksanakan, seperti lupa untuk menambah tag akhir.

Apakah perbezaan antara termasuk, memerlukan, termasuk_once, memerlukan_once? Apakah perbezaan antara termasuk, memerlukan, termasuk_once, memerlukan_once? Apr 05, 2025 am 12:07 AM

Dalam PHP, perbezaan antara termasuk, memerlukan, termasuk_once, memerlukan_once adalah: 1) termasuk menghasilkan amaran dan terus melaksanakan, 2) memerlukan menghasilkan ralat maut dan berhenti pelaksanaan, 3) termasuk_once dan memerlukan_once mencegah kemasukan berulang. Pilihan fungsi ini bergantung kepada kepentingan fail dan sama ada perlu untuk mencegah kemasukan pendua. Penggunaan rasional dapat meningkatkan kebolehbacaan dan pemeliharaan kod.

PHP dan Python: Membandingkan dua bahasa pengaturcaraan yang popular PHP dan Python: Membandingkan dua bahasa pengaturcaraan yang popular Apr 14, 2025 am 12:13 AM

PHP dan Python masing -masing mempunyai kelebihan mereka sendiri, dan memilih mengikut keperluan projek. 1.PHP sesuai untuk pembangunan web, terutamanya untuk pembangunan pesat dan penyelenggaraan laman web. 2. Python sesuai untuk sains data, pembelajaran mesin dan kecerdasan buatan, dengan sintaks ringkas dan sesuai untuk pemula.

PHP: Bahasa utama untuk pembangunan web PHP: Bahasa utama untuk pembangunan web Apr 13, 2025 am 12:08 AM

PHP adalah bahasa skrip yang digunakan secara meluas di sisi pelayan, terutamanya sesuai untuk pembangunan web. 1.PHP boleh membenamkan HTML, memproses permintaan dan respons HTTP, dan menyokong pelbagai pangkalan data. 2.PHP digunakan untuk menjana kandungan web dinamik, data borang proses, pangkalan data akses, dan lain -lain, dengan sokongan komuniti yang kuat dan sumber sumber terbuka. 3. PHP adalah bahasa yang ditafsirkan, dan proses pelaksanaan termasuk analisis leksikal, analisis tatabahasa, penyusunan dan pelaksanaan. 4.Php boleh digabungkan dengan MySQL untuk aplikasi lanjutan seperti sistem pendaftaran pengguna. 5. Apabila debugging php, anda boleh menggunakan fungsi seperti error_reporting () dan var_dump (). 6. Mengoptimumkan kod PHP untuk menggunakan mekanisme caching, mengoptimumkan pertanyaan pangkalan data dan menggunakan fungsi terbina dalam. 7

Apakah kaedah permintaan HTTP (dapatkan, pos, letakkan, padam, dll) dan kapan masing -masing harus digunakan? Apakah kaedah permintaan HTTP (dapatkan, pos, letakkan, padam, dll) dan kapan masing -masing harus digunakan? Apr 09, 2025 am 12:09 AM

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.

See all articles