2109. Menambah Ruang pada Rentetan
Kesukaran: Sederhana
Topik: Tatasusunan, Dua Penunjuk, Rentetan, Simulasi
Anda diberi ruang tatasusunan integer 0-indeks dan 0-indeks rentetan yang menerangkan indeks dalam rentetan asal tempat ruang akan ditambah. Setiap ruang hendaklah disisipkan sebelum aksara pada indeks yang diberikan.
- Sebagai contoh, diberi s = "Nikmati Kopi Anda" dan ruang = [5, 9], kami meletakkan ruang sebelum 'Y' dan 'C', yang masing-masing berada pada indeks 5 dan 9. Oleh itu, kami memperoleh "Nikmati Kopi Anda".
Kembalikan rentetan yang diubah suai selepas ruang telah ditambahkan.
Contoh 1:
- Input: s = "LeetcodeHelpsMeLearn", ruang = [8,13,15]
- Output: "Leetcode Membantu Saya Belajar"
-
Penjelasan: Indeks 8, 13 dan 15 sepadan dengan aksara yang digariskan dalam "LeetcodeHelpsMeLearn".
- Kami kemudian meletakkan ruang sebelum aksara tersebut.
Contoh 2:
- Input: s = "icodeinpython", ruang = [1,5,7,9]
- Output: "i kod dalam py thon"
-
Penjelasan: Indeks 1, 5, 7, dan 9 sepadan dengan aksara yang digariskan dalam "icodeinpython".
- Kami kemudian meletakkan ruang sebelum aksara tersebut.
Contoh 3:
- Input: s = "jarak", ruang = [0,1,2,3,4,5,6]
- Output: " s p a c i n g"
- Penjelasan: Kami juga dapat meletakkan ruang sebelum aksara pertama rentetan.
Kekangan:
- 1 5
- s hanya terdiri daripada huruf kecil dan huruf besar Inggeris.
- 1 5
- 0
- Semua nilai ruang meningkat dengan ketat.
Petunjuk:
- Buat rentetan baharu, pada mulanya kosong, sebagai rentetan yang diubah suai. Lelaran melalui rentetan asal dan tambahkan setiap aksara rentetan asal pada rentetan baharu. Walau bagaimanapun, setiap kali anda mencapai watak yang memerlukan ruang di hadapannya, tambahkan ruang sebelum menambahkan watak itu.
- Memandangkan tatasusunan indeks untuk lokasi ruang diisih, gunakan penuding untuk menjejaki indeks seterusnya untuk meletakkan ruang. Hanya naikkan penunjuk apabila ruang telah ditambahkan.
- Pastikan operasi tambah anda boleh dilakukan dalam O(1).
Penyelesaian:
Kita boleh menggunakan pendekatan yang cekap dengan dua petunjuk. Begini rupa pelaksanaan dalam PHP 5.6:
Penjelasan Penyelesaian:
- Gunakan spaceIndex penunjuk untuk menjejaki kedudukan semasa dalam tatasusunan ruang.
- Lelaran melalui rentetan s menggunakan gelung.
- Semak sama ada indeks semasa dalam rentetan sepadan dengan nilai semasa dalam tatasusunan ruang. Jika ya, tambahkan ruang pada hasil carian dan gerakkan penunjuk spaceIndex ke hadapan.
- Tambahkan aksara semasa rentetan pada hasil carian.
- Kembalikan hasil akhir sebagai rentetan tunggal.
Pendekatan ini memastikan kami memproses input dengan cekap, mengambil kesempatan daripada tertib disusun tatasusunan ruang.
Mari kita laksanakan penyelesaian ini dalam PHP: 2109. Menambah Ruang pada Rentetan
<?php /** * @param String $s * @param Integer[] $spaces * @return String */ function addSpaces($s, $spaces) { ... ... ... /** * go to ./solution.php */ } // Example 1 $s1 = "LeetcodeHelpsMeLearn"; $spaces1 = [8, 13, 15]; echo addSpaces($s1, $spaces1) . "\n"; // Output: "Leetcode Helps Me Learn" // Example 2 $s2 = "icodeinpython"; $spaces2 = [1, 5, 7, 9]; echo addSpaces($s2, $spaces2) . "\n"; // Output: "i code in py thon" // Example 3 $s3 = "spacing"; $spaces3 = [0, 1, 2, 3, 4, 5, 6]; echo addSpaces($s3, $spaces3) . "\n"; // Output: " s p a c i n g" ?>
Penjelasan:
- Pelampiran yang Cekap: . operator dalam PHP digunakan untuk menambahkan rentetan dengan cekap.
- Dua Penunjuk: Penunjuk spaceIndex memastikan kami hanya memproses tatasusunan ruang sekali.
-
Kerumitan Masa:
- Mengulang rentetan mengambil masa O(n), dengan n ialah panjang rentetan.
- Menyemak terhadap penunjuk tatasusunan ruang mengambil masa O(m), dengan m ialah panjang tatasusunan ruang.
- Gabungan: O(n m), yang optimum memandangkan kekangan.
Penyelesaian ini mematuhi kekangan dan cekap walaupun untuk input yang besar.
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:
- GitHub
Atas ialah kandungan terperinci Menambah Ruang pada Rentetan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

ThedifferenceBetweenUnset () andSession_destroy () isThatunset () clearsspecificSessionVariableswhileKeepingTheSessionActive, sedangkan assesion_destroy () terminatestheentiressies.1)

StickySessionseSenseSerRequestSarerOutedTotheseServerForSessionDataConsistency.1) sessionentificationassignsuserverserversusingciesorurlmodifications.2) consistentroutingdirectssubsequentrequeststotheserver.3) loadbalansingdistributesNewuser

Phpoffersvarioussessionsavehandlers: 1) Fail: lalai, SimpleButmayBottLeneckonHigh-Trafficsites.2) Memcached: berprestasi tinggi, idealforspeed-kritikalapplications.3) Redis: similartomemcached

Sesi dalam PHP adalah mekanisme untuk menyimpan data pengguna di sisi pelayan untuk mengekalkan keadaan antara pelbagai permintaan. Khususnya, 1) sesi dimulakan oleh fungsi session_start (), dan data disimpan dan dibaca melalui array super global $ _Session; 2) data sesi disimpan dalam fail sementara pelayan secara lalai, tetapi boleh dioptimumkan melalui pangkalan data atau storan memori; 3) Sesi ini boleh digunakan untuk merealisasikan fungsi pengesan status pengguna dan fungsi keranjang belanja; 4) Perhatikan pengoptimuman penghantaran dan prestasi yang selamat bagi sesi untuk memastikan keselamatan dan kecekapan permohonan.

PHPSSsionsStartWithSesion_start (), yang manageneratesauniqueidAndreateSererVerVerFile; tHePersisTacrossRequestSandCanBeManualEltersenedWithSession_destroy ()

Timeout sesi mutlak bermula pada masa penciptaan sesi, sementara waktu tamat sesi terbiar bermula pada masa operasi pengguna. Tamat masa sesi mutlak sesuai untuk senario di mana kawalan ketat kitaran hayat sesi diperlukan, seperti aplikasi kewangan; Timeout sesi terbiar sesuai untuk aplikasi yang mahu pengguna menyimpan sesi mereka aktif untuk masa yang lama, seperti media sosial.

Kegagalan sesi pelayan boleh diselesaikan dengan mengikuti langkah -langkah: 1. Semak konfigurasi pelayan untuk memastikan sesi ditetapkan dengan betul. 2. Sahkan kuki klien, sahkan bahawa penyemak imbas menyokongnya dan hantar dengan betul. 3. Periksa perkhidmatan penyimpanan sesi, seperti Redis, untuk memastikan bahawa mereka beroperasi secara normal. 4. Semak kod aplikasi untuk memastikan logik sesi yang betul. Melalui langkah -langkah ini, masalah perbualan dapat didiagnosis dengan berkesan dan diperbaiki dan pengalaman pengguna dapat diperbaiki.

session_start () iscrucialinphpformanaginguserSessions.1) itinitiatesanewsessionifnoneexists, 2) resumeSanexistingsession, dan3) setSasessionCookieforcontinuityAcrossrequests, enableingApplicationeUseUshenticationandPersonalConizedConizedContentContentContentContentContentContentContentContentContentContentContentC.


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

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

Artikel Panas

Alat panas

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Dreamweaver CS6
Alat pembangunan web visual

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

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.
