欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java C++題解leetcode915分割數(shù)組示例

 更新時間:2022年11月02日 17:12:45   作者:AnjaVon  
這篇文章主要為大家介紹了Java C++題解leetcode915分割數(shù)組示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

題目要求

題目鏈接

思路一:兩次遍歷

題目的意思也就是左半邊數(shù)組的最大值小于等于右半邊數(shù)組的最小值,那么就找這個分界點就好;

  • 首先從后向前遍歷,找[i,n−1]里最小的值;
  • 然后從前向后遍歷,找[0,i]里最大的值;
  • 然后找滿足max[i]<=min[i+1]的分割點i;
  • 可以將2、3兩步結合為一步完成,由于iii從前向后不斷增大,所以用后面(較大)的值覆蓋更新之前的值。

找到分界點的索引后,只需+1即可得到長度。

Java

class Solution {
    public int partitionDisjoint(int[] nums) {
        int n = nums.length;
        int[] minn = new int[n + 10];
        minn[n - 1] = nums[n - 1];
        for (int i = n - 2; i >= 0; i--)
            minn[i] = Math.min(minn[i + 1], nums[i]);
        for (int i = 0, maxx = 0; i < n - 1; i++) {
            maxx = Math.max(maxx, nums[i]);
            if (maxx <= minn[i + 1])
                return i + 1;
        }
        return 1; // 用例保證不出現(xiàn)
    }
}
  • 時間復雜度:O(n)
  • 空間復雜度:O(n)

C++

class Solution {
public:
    int partitionDisjoint(vector<int>& nums) {
        int n = nums.size();
        int minn[n + 10];
        minn[n - 1] = nums[n - 1];
        for (int i = n - 2; i >= 0; i--)
            minn[i] = min(minn[i + 1], nums[i]);
        for (int i = 0, maxx = 0; i < n - 1; i++) {
            maxx = max(maxx, nums[i]);
            if (maxx <= minn[i + 1])
                return i + 1;
        }
        return 1; // 用例保證不出現(xiàn)
    }
};
  • 時間復雜度:O(n)
  • 空間復雜度:O(n)

Rust

impl Solution {
    pub fn partition_disjoint(nums: Vec<i32>) -> i32 {
        let n = nums.len();
        let mut minn = vec![nums[n - 1]; n + 10];
        for i in (0..(n - 1)).rev() {
            minn[i] = minn[i + 1].min(nums[i]);
        }
        let mut maxx = 0;
        for i in 0..(n - 1) {
            maxx = maxx.max(nums[i]);
            if (maxx <= minn[i + 1]) {
                return (i + 1) as i32;
            }
        }
        return 1; // 用例保證不出現(xiàn)
    }
}
  • 時間復雜度:O(n)
  • 空間復雜度:O(n)

思路二:一次遍歷

從前向后遍歷每個節(jié)點,依次假設每個節(jié)點為最終分界點;

  • 維護當前遍歷節(jié)點的最大值maxx,即[0,i]內(nèi);
  • 記錄假設分界點i及其對應左半邊數(shù)組最大值leftMax;

若當前值nums[i]<leftMax則重新劃定分界,將當前節(jié)點納入左區(qū)間;

找到最終結果節(jié)點索引值,將其+1即得答案。

Java

class Solution {
    public int partitionDisjoint(int[] nums) {
        int leftMax = nums[0], res = 0, maxx = nums[0];
        for (int i = 1; i < nums.length - 1; i++) {
            maxx = Math.max(maxx, nums[i]);
            if (nums[i] < leftMax) {
                leftMax = maxx;
                res = i;
            }
        }
        return res + 1;
    }
}
  • 時間復雜度:O(n)
  • 空間復雜度:O(1)

C++

class Solution {
public:
    int partitionDisjoint(vector<int>& nums) {
        int leftMax = nums[0], res = 0, maxx = nums[0];
        for (int i = 1; i < nums.size() - 1; i++) {
            maxx = max(maxx, nums[i]);
            if (nums[i] < leftMax) {
                leftMax = maxx;
                res = i;
            }
        }
        return res + 1;
    }
};
  • 時間復雜度:O(n)
  • 空間復雜度:O(1)

Rust

impl Solution {
    pub fn partition_disjoint(nums: Vec<i32>) -> i32 {
        let (mut leftMax, mut res, mut maxx) = (nums[0], 0, nums[0]);
        for i in 1..(nums.len()-1) {
            maxx = maxx.max(nums[i]);
            if nums[i] < leftMax {
                leftMax = maxx;
                res = i as i32;
            }
        }
        res + 1
    }
}
  • 時間復雜度:O(n)
  • 空間復雜度:O(1)

以上就是Java C++題解leetcode915分割數(shù)組示例的詳細內(nèi)容,更多關于Java C++題解分割數(shù)組的資料請關注腳本之家其它相關文章!

相關文章

  • C語言編一個數(shù)字益智小游戲

    C語言編一個數(shù)字益智小游戲

    這篇文章主要介紹了C語言編一個數(shù)字益智小游戲,本文通過實例截圖的形式給大家展示的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • C語言函數(shù)棧幀詳解

    C語言函數(shù)棧幀詳解

    下面小編就為大家?guī)硪黄獪\談C語言函數(shù)調(diào)用參數(shù)壓棧的相關問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • VC++獲得當前進程運行目錄的方法

    VC++獲得當前進程運行目錄的方法

    這篇文章主要介紹了VC++獲得當前進程運行目錄的方法,可通過系統(tǒng)函數(shù)實現(xiàn)該功能,是非常實用的技巧,需要的朋友可以參考下
    2014-10-10
  • C語言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實現(xiàn)

    C語言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實現(xiàn)

    這篇文章主要介紹了C語言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實現(xiàn),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 基于C語言實現(xiàn)的aes256加密算法示例

    基于C語言實現(xiàn)的aes256加密算法示例

    這篇文章主要介紹了基于C語言實現(xiàn)的aes256加密算法,結合具體實例形式詳細分析了C語言實現(xiàn)的aes256加密算法實現(xiàn)步驟與使用技巧,需要的朋友可以參考下
    2017-02-02
  • C++輕量級界面開發(fā)框架ImGUI介紹小結

    C++輕量級界面開發(fā)框架ImGUI介紹小結

    如果從事過C++?Windows客戶端開發(fā),大家對MFC、Qt、DuiLib等各種DirectUI應該有了解,本篇給大家介紹一個超級輕量級的C++開源跨平臺圖形界面框架ImGUI,感興趣的可以了解一下
    2021-11-11
  • Qt實現(xiàn)密碼顯示按鈕

    Qt實現(xiàn)密碼顯示按鈕

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)密碼顯示按鈕,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • C++替換棧中和.data中的cookie實現(xiàn)步驟詳解

    C++替換棧中和.data中的cookie實現(xiàn)步驟詳解

    這篇文章主要介紹了C++替換棧中和.data中的cookie實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • C++超詳細分析單鏈表的實現(xiàn)與常見接口

    C++超詳細分析單鏈表的實現(xiàn)與常見接口

    鏈表是一種物理存儲結構上非連續(xù)、非順序的存儲結構,數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的,本章帶你分析單鏈表的實現(xiàn)與常見接口
    2022-03-03
  • C/C++中指針和引用之相關問題深入研究

    C/C++中指針和引用之相關問題深入研究

    從內(nèi)存分配上看,程序為指針變量分配內(nèi)存區(qū)域,而不為引用分配內(nèi)存區(qū)域,因為引用聲明時必須初始化,從而指向一個已經(jīng)存在的對象。引用不能指向空值
    2013-10-10

最新評論