Mengalihkan Nilai Bukan Sifar Ke Kiri: Masalah Temu Bual Tatasusunan Biasa-1
pengenalan
Dalam temu bual teknikal, masalah manipulasi tatasusunan sering dihadapi. Dalam siaran ini, kami akan menangani masalah biasa: Menukar nilai bukan sifar ke kiri sambil mengekalkan susunan unsur bukan sifar dan menolak semua sifar ke kanan.
Jika anda tidak biasa dengan konsep tatasusunan asas, saya syorkan anda menyemak Memahami Asas Tatasusunan dalam Java: Panduan Mudah untuk meningkatkan kelajuan!
Pernyataan Masalah
Memandangkan tatasusunan integer, tugas anda ialah mengalihkan semua elemen bukan sifar ke sebelah kiri sambil menolak semua unsur sifar ke kanan. Susunan relatif unsur bukan sifar mesti dikekalkan.
Contoh:
Input: [1, 2, 0, 3, 0, 0, 4, 3, 2, 9] Output: [1, 2, 3, 4, 3, 2, 9, 0, 0, 0]
Pendekatan
Kita boleh menyelesaikan masalah ini dalam O(n) masa menggunakan satu laluan melalui tatasusunan, dan penyelesaiannya akan mempunyai kerumitan ruang O(1).
- Gunakan penuding untuk menjejaki indeks bagi elemen bukan sifar seterusnya.
- Lelar melalui tatasusunan, meletakkan elemen bukan sifar pada indeks penuding.
- Naikkan penunjuk setiap kali elemen bukan sifar diletakkan.
Kod
package arrays; // Time Complexity - O(n) // Space Complexity - O(1) public class ShiftNonZeroValuesToLeft { private void shiftValues(int[] inputArray) { /* Variable to keep track of index position to be filled with Non-Zero Value */ int pointer = 0; // If value is Non-Zero then place it at the pointer index for (int i = 0; i <h2> Penjelasan </h2>
Kaedah shiftValues berulang melalui tatasusunan input.
Jika nilai bukan sifar ditemui, ia diletakkan pada indeks penunjuk semasa dan elemen pada indeks semasa digantikan dengan 0.
Penunjuk kemudiannya dinaikkan untuk menjejaki kedudukan seterusnya bagi elemen bukan sifar.
Jika sudah ada nilai bukan sifar pada kedudukan yang betul (iaitu, pada indeks penunjuk), kaedah hanya menambah penunjuk tanpa membuat sebarang pertukaran.
Ini berterusan sehingga keseluruhan tatasusunan diproses.
Kerumitan Masa & Ruang
Kerumitan Masa: O(n), dengan n ialah panjang tatasusunan.
Kerumitan Ruang: O(1), memandangkan kami sedang mengubah suai tatasusunan di tempatnya.
Kes Tepi
Semua Sifar: Jika tatasusunan mengandungi semua sifar, ia akan kekal tidak berubah.
Tiada Sifar: Jika tiada sifar, susunan unsur asal dikekalkan.
Susun Kosong: Fungsi harus mengendalikan tatasusunan kosong tanpa masalah.
Kesimpulan
Masalah ini mempamerkan kepentingan memahami teknik manipulasi tatasusunan dan kecekapannya dalam temu bual pengekodan. Menguasai masalah sebegini boleh meningkatkan kemahiran menyelesaikan masalah anda!
Atas ialah kandungan terperinci Mengalihkan Nilai Bukan Sifar Ke Kiri: Masalah Temu Bual Tatasusunan Biasa-1. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


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

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma