Java C++題解leetcode915分割數(shù)組示例
題目要求
思路一:兩次遍歷
題目的意思也就是左半邊數(shù)組的最大值小于等于右半邊數(shù)組的最小值,那么就找這個(gè)分界點(diǎn)就好;
- 首先從后向前遍歷,找[i,n−1]里最小的值;
- 然后從前向后遍歷,找[0,i]里最大的值;
- 然后找滿足max[i]<=min[i+1]的分割點(diǎn)i;
- 可以將2、3兩步結(jié)合為一步完成,由于iii從前向后不斷增大,所以用后面(較大)的值覆蓋更新之前的值。
找到分界點(diǎn)的索引后,只需+1即可得到長(zhǎng)度。
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) } }
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度: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) } };
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度: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) } }
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度:O(n)
思路二:一次遍歷
從前向后遍歷每個(gè)節(jié)點(diǎn),依次假設(shè)每個(gè)節(jié)點(diǎn)為最終分界點(diǎn);
- 維護(hù)當(dāng)前遍歷節(jié)點(diǎn)的最大值maxx,即[0,i]內(nèi);
- 記錄假設(shè)分界點(diǎn)i及其對(duì)應(yīng)左半邊數(shù)組最大值leftMax;
若當(dāng)前值nums[i]<leftMax則重新劃定分界,將當(dāng)前節(jié)點(diǎn)納入左區(qū)間;
找到最終結(jié)果節(jié)點(diǎn)索引值,將其+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; } }
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度: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; } };
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度: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 } }
- 時(shí)間復(fù)雜度:O(n)
- 空間復(fù)雜度:O(1)
以上就是Java C++題解leetcode915分割數(shù)組示例的詳細(xì)內(nèi)容,更多關(guān)于Java C++題解分割數(shù)組的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Java?C++刷題leetcode1106解析布爾表達(dá)式
- Java C++題解leetcode816模糊坐標(biāo)示例
- Java C++題解leetcode 1684統(tǒng)計(jì)一致字符串的數(shù)目示例
- Java?C++題解leetcode764最大加號(hào)標(biāo)志示例
- Java?C++題解leetcode904水果成籃
- Java?C++題解leetcode902最大為N的數(shù)字組合數(shù)位DP
- Java?C++?leetcode面試零矩陣
- Java C++題解leetcode1620網(wǎng)絡(luò)信號(hào)最好的坐標(biāo)
相關(guān)文章
VC++獲得當(dāng)前進(jìn)程運(yùn)行目錄的方法
這篇文章主要介紹了VC++獲得當(dāng)前進(jìn)程運(yùn)行目錄的方法,可通過(guò)系統(tǒng)函數(shù)實(shí)現(xiàn)該功能,是非常實(shí)用的技巧,需要的朋友可以參考下2014-10-10C語(yǔ)言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實(shí)現(xiàn)
這篇文章主要介紹了C語(yǔ)言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實(shí)現(xiàn),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09基于C語(yǔ)言實(shí)現(xiàn)的aes256加密算法示例
這篇文章主要介紹了基于C語(yǔ)言實(shí)現(xiàn)的aes256加密算法,結(jié)合具體實(shí)例形式詳細(xì)分析了C語(yǔ)言實(shí)現(xiàn)的aes256加密算法實(shí)現(xiàn)步驟與使用技巧,需要的朋友可以參考下2017-02-02C++輕量級(jí)界面開(kāi)發(fā)框架ImGUI介紹小結(jié)
如果從事過(guò)C++?Windows客戶端開(kāi)發(fā),大家對(duì)MFC、Qt、DuiLib等各種DirectUI應(yīng)該有了解,本篇給大家介紹一個(gè)超級(jí)輕量級(jí)的C++開(kāi)源跨平臺(tái)圖形界面框架ImGUI,感興趣的可以了解一下2021-11-11C++替換棧中和.data中的cookie實(shí)現(xiàn)步驟詳解
這篇文章主要介紹了C++替換棧中和.data中的cookie實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-10-10C++超詳細(xì)分析單鏈表的實(shí)現(xiàn)與常見(jiàn)接口
鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的,本章帶你分析單鏈表的實(shí)現(xiàn)與常見(jiàn)接口2022-03-03C/C++中指針和引用之相關(guān)問(wèn)題深入研究
從內(nèi)存分配上看,程序?yàn)橹羔樧兞糠峙鋬?nèi)存區(qū)域,而不為引用分配內(nèi)存區(qū)域,因?yàn)橐寐暶鲿r(shí)必須初始化,從而指向一個(gè)已經(jīng)存在的對(duì)象。引用不能指向空值2013-10-10