搜尋
首頁Javajava教程Leetcode——Digitville 的兩個偷偷摸摸的數字

Leetcode — The Two Sneaky Numbers of Digitville

這是一個簡單的問題,描述為:

在 Digitville 鎮上,有一個名為 nums 的數字列表,其中包含從 0 到 n - 1 的整數。每個數字都應該在清單中只出現一次,然而,兩個頑皮的數字額外出現了一次,使得清單比平常更長。

身為小鎮偵探,你的任務就是找到這兩個鬼祟的數字。傳回一個大小為 2 的數組,其中包含兩個數字(以任意順序),這樣 Digitville 就能恢復和平。

範例1:

輸入:nums = [0,1,1,0]

輸出:[0,1]

說明:

數字 0 和 1 在陣列中各出現兩次。

範例2:

輸入:nums = [0,3,2,1,3,2]

輸出:[2,3]

說明:

數字 2 和 3 在陣列中各出現兩次。

範例3:

輸入:nums = [7,1,5,4,3,4,6,0,9,5,8,2]

輸出:[4,5]

說明:

數字 4 和 5 在陣列中各出現兩次。

限制:

2

nums.length == n 2

0

產生的輸入使得 nums 恰好包含兩個重複元素。

這個問題有很多方法可以解決,你可以使用集合、映射、數組作為映射,甚至使用位,但由於這是一個簡單的問題,也許我們不應該深入兔子洞。

對於解決方案,我採用了簡單的方法,即對數組進行排序,然後在迭代中檢查前一個數字是否相等,如果是,則添加到我的結果中,就是這樣:

class Solution {
    public int[] getSneakyNumbers(int[] nums) {

        // build the response and the pivot for the first item of the response array
        int pivot = 0;
        int[] response = new int[2];

        // sort nums array to make it easy to identify duplication
        Arrays.sort(nums);

        // iterate and numbers nearby are the ones considered sneaky, grab them and add into the response
        for(int i=1;i<nums.length if response nums pivot return>



<blockquote>
<p>運行時間:2毫秒,比70.75%的Java線上提交快。 </p>

<p>記憶體使用:44.49 MB,低於 Java 線上提交的 86.86%。 </p>
</blockquote>

<p>如果您確定不會超過兩個,您可以進行額外檢查,但除此之外,此解決方案滿足了大部分需求。 </p>

<p>—</p>

<p>就是這樣!如果還有什麼要討論的,請隨時發表評論,如果我錯過了任何內容,請告訴我,以便我進行相應更新。 </p>

<p>直到下一篇文章! :)</p>


          

            
        </nums.length>

以上是Leetcode——Digitville 的兩個偷偷摸摸的數字的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
java主要是乾嘛的 Java在實際開發中的主要用途解析java主要是乾嘛的 Java在實際開發中的主要用途解析May 16, 2025 pm 02:54 PM

Java主要用於構建桌面應用、移動應用、企業級解決方案和大數據處理。 1.企業級應用:通過JavaEE支持複雜應用,如銀行系統。 2.Web開發:使用Spring、Hibernate簡化開發,SpringBoot快速搭建微服務。 3.移動應用:仍是Android開發主要語言之一。 4.大數據處理:Hadoop和Spark基於Java處理海量數據。 5.遊戲開發:適用於中小型遊戲開發,如Minecraft。

java怎麼設置為中文 Java開發工具中文界面設置教程java怎麼設置為中文 Java開發工具中文界面設置教程May 16, 2025 pm 02:51 PM

如何將Java開發工具設置為中文界面?可以通過以下步驟實現:Eclipse:Window->Preferences->General->Appearance->I18nsupport->Language->Chinese(Simplified),然後重啟Eclipse。 IntelliJIDEA:Help->FindAction->輸入"switchlanguage"->選擇"SwitchIDELanguage&q

學java要學多久才能工作 Java學習週期和就業時間預估學java要學多久才能工作 Java學習週期和就業時間預估May 16, 2025 pm 02:48 PM

學習Java並達到工作水平通常需要6到12個月,對於有編程基礎的人可能縮短至3到6個月。 1)零基礎學習者需6-12個月掌握基礎和常用庫。 2)有編程基礎者可能3-6個月內掌握。 3)就業時間在學習9-18個月後,實際項目和實習可加速進程。

java中的new是什麼 new操作符的內存分配過程java中的new是什麼 new操作符的內存分配過程May 16, 2025 pm 02:45 PM

在Java中,new操作符用於創建對象,其過程包括:1)在堆內存中分配空間,2)初始化對象,3)調用構造函數,4)返回對象引用。理解這些步驟有助於優化內存使用和提升應用程序性能。

java中數組如何定義 數組聲明的語法格式說明java中數組如何定義 數組聲明的語法格式說明May 16, 2025 pm 02:42 PM

在Java中定義數組的語法是:1.數據類型[]數組名=new數據類型[數組長度];2.數據類型數組名[]=new數據類型[數組長度];3.數據類型[]數組名={元素列表};數組是對象,可為null,下標從0開始,使用時需注意潛在的錯誤如NullPointerException和ArrayIndexOutOfBoundsException。

java中new關鍵字的用法 new關鍵字創建對象實例詳解java中new關鍵字的用法 new關鍵字創建對象實例詳解May 16, 2025 pm 02:39 PM

new關鍵字在Java中用於創建對象實例。 1)它告訴JVM分配內存並調用構造函數初始化對象。 2)使用new可以強制創建新對象,即使內容相同。 3)構造函數允許自定義初始化。 4)頻繁使用new可能導致性能問題和內存洩漏。 5)需要使用try-catch處理可能的異常。 6)匿名內部類是new的高級用法。

java中文亂碼解決方法 字符編碼轉換的幾種技巧java中文亂碼解決方法 字符編碼轉換的幾種技巧May 16, 2025 pm 02:36 PM

解決Java中的中文亂碼問題可以通過以下步驟:1.設置正確的字符編碼,如UTF-8或GBK,確保文件、數據庫和網絡通信使用相同編碼。 2.使用Java的字符編碼轉換類進行必要的編碼轉換。 3.通過調試工具和日誌驗證編碼是否正確,確保在不同環境下中文顯示正常。

java中異常分為哪兩類 檢查型和非檢查型異常區別java中異常分為哪兩類 檢查型和非檢查型異常區別May 16, 2025 pm 02:33 PM

Java中的異常分為檢查型異常和非檢查型異常。檢查型異常必須顯式處理,否則編譯器報錯,常用於可恢復錯誤,如文件未找到;非檢查型異常無需顯式處理,常用於編程錯誤,如空指針異常。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。