LintCode 31. 數(shù)組劃分

原題

第一步,萬(wàn)年不變的查錯(cuò)。如果給的array是null或空,直接return 0

    public int partitionArray(int[] nums, int k) {
        if(nums == null || nums.length == 0) {
            return 0;
        }
        ...
    }

這道題很簡(jiǎn)單,簡(jiǎn)直對(duì)不起medium難度。分明就是quickSort的第一步嘛??偟膩?lái)說(shuō),就是左右兩個(gè)pointer,左邊如果碰到大于等于k的,右邊如果碰到小于k的,那么就左右互換。最后return那個(gè),可能需要想一下,要求nums[index]必須大于等于k。這個(gè)while loop的結(jié)束條件就是左邊超過(guò)右邊,所以其實(shí)左邊比右邊大,所以最后要return left;
直接上完整的code了,沒(méi)有難度。

public class Solution {
    /*
     * @param nums: The integer array you should partition
     * @param k: An integer
     * @return: The index after partition
     */
    public int partitionArray(int[] nums, int k) {
        if(nums == null || nums.length == 0) {
            return 0;
        }
        
        int left = 0;
        int right = nums.length - 1;
        while (left <= right) {
            while (left <= right && nums[left] < k) {
                left++;
            }
            
            while (left <= right && nums[right] >= k) {
                right --;
            }
            
            if (left <= right) {
                swap(nums, left, right);
            }
        }
        
        return left;
    }
    
    private void swap(int[] nums, int left, int right) {
        int temp = nums[left];
        nums[left] = nums[right];
        nums[right] = temp;
    }
}

分析

時(shí)間復(fù)雜度

只遍歷了一次,所以O(shè)(n)。

空間復(fù)雜度

O(1)。

總的來(lái)說(shuō),太簡(jiǎn)單了。更簡(jiǎn)單的一種方法其實(shí)是一次遍歷,數(shù)比k小的數(shù)字有幾個(gè),然后返回。如果真的面試碰到的話,應(yīng)該不要傻傻的直接two pointer。應(yīng)該先說(shuō)最明顯也是最簡(jiǎn)單的答案,然后等人家followup。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問(wèn)題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,929評(píng)論 0 33
  • 課程介紹 先修課:概率統(tǒng)計(jì),程序設(shè)計(jì)實(shí)習(xí),集合論與圖論 后續(xù)課:算法分析與設(shè)計(jì),編譯原理,操作系統(tǒng),數(shù)據(jù)庫(kù)概論,人...
    ShellyWhen閱讀 2,471評(píng)論 0 3
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類(lèi)相關(guān)的語(yǔ)法,內(nèi)部類(lèi)的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚(yú)_t_閱讀 34,806評(píng)論 18 399
  • 單身只是一個(gè)現(xiàn)象,我至今單身,并不是因?yàn)榍樯痰?,不是不敢再?ài),不是怕受傷,也不是還忘不了誰(shuí),沒(méi)什么狗血特別的原因,...
    Suthy閱讀 245評(píng)論 0 0
  • 原文地址這是一個(gè)系列文章,查看更多請(qǐng)移步目錄頁(yè) Code coverage 是一個(gè)計(jì)算你的單元測(cè)試覆蓋率的工具。高...
    Nathan_Bao閱讀 3,819評(píng)論 0 13

友情鏈接更多精彩內(nèi)容