<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
題目的意思也就是左半邊陣列的最大值小於等於右半邊陣列的最小值,那麼就找這個分界點就好;
找到分界點的索引後,只需+1即可得到長度。
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; // 用例保證不出現 } }
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; // 用例保證不出現 } };
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; // 用例保證不出現 } }
從前向後遍歷每個節點,依次假設每個節點為最終分界點;
若當前值nums[i]<leftMax則重新劃定分界,將當前節點納入左區間;
找到最終結果節點索引值,將其+1即得答案。
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; } }
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; } };
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 } }
以上就是Java C++題解leetcode915分割陣列範例的詳細內容,更多關於Java C++題解分割陣列的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45