介紹
在技術面試中,常常會遇到陣列操作問題。在這篇文章中,我們將解決一個常見問題:將非零值向左移動,同時保持非零元素的順序並將所有零推到右側。
如果您不熟悉基本的陣列概念,我建議您查看《Understanding Array Basics in Java: A Simple Guide》以快速入門!
問題陳述
給定一個整數數組,您的任務是將所有非零元素移動到左側,同時將所有零元素推到右側。必須保留非零元素的相對順序。
範例:
Input: [1, 2, 0, 3, 0, 0, 4, 3, 2, 9] Output: [1, 2, 3, 4, 3, 2, 9, 0, 0, 0]
方法
我們可以使用單次遍歷數組在 O(n) 時間內解決這個問題,而解的空間複雜度為 O(1)。
- 使用指標追蹤下一個非零元素的索引。
- 迭代數組,將非零元素放置在指標的索引處。
- 每次放置非零元素時都會增加指針。
守則
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> 解釋 </h2>
shiftValues 方法迭代輸入陣列。
如果找到非零值,則將其放置在目前指標索引處,並將目前索引處的元素替換為 0。
然後指標遞增以追蹤非零元素的下一個位置。
如果正確位置(即指標索引處)已經有一個非零值,則該方法只是遞增指標而不進行任何交換。
這將持續到處理整個陣列為止。
時間和空間複雜性
時間複雜度: O(n),其中 n 是陣列的長度。
空間複雜度: O(1),因為我們正在就地修改陣列。
邊緣情況
全零:如果陣列包含全零,則保持不變。
沒有零:如果沒有零,則保留元素的原始順序。
空數組: 函數應該毫無問題地處理空數組。
結論
這個問題展示了理解數組操作技術及其在編碼面試中的效率的重要性。掌握這樣的問題可以大大提升你解決問題的能力!
以上是左移非零值:公共數組面試問題 1的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

WebStorm Mac版
好用的JavaScript開發工具

記事本++7.3.1
好用且免費的程式碼編輯器

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。