zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 769 最多能完成排序的块(单向遍历)

    769. 最多能完成排序的块

    数组arr是[0, 1, …, arr.length - 1]的一种排列,我们将这个数组分割成几个“块”,并将这些块分别进行排序。之后再连接起来,使得连接的结果和按升序排序后的原数组相同。

    我们最多能将数组分成多少块?

    示例 1:

    输入: arr = [4,3,2,1,0]
    输出: 1
    解释:
    将数组分成2块或者更多块,都无法得到所需的结果。
    例如,分成 [4, 3], [2, 1, 0] 的结果是 [3, 4, 0, 1, 2],这不是有序的数组。
    示例 2:

    输入: arr = [1,0,2,3,4]
    输出: 4
    解释:
    我们可以把它分成两块,例如 [1, 0], [2, 3, 4]。
    然而,分成 [1, 0], [2], [3], [4] 可以得到最多的块数。
    注意:

    arr 的长度在 [1, 10] 之间。
    arr[i]是 [0, 1, …, arr.length - 1]的一种排列。

    class Solution {
         public int maxChunksToSorted(int[] arr) {
            int n = arr.length;
            int i = 0;
            int max = 0;
            while(i < n){
                int bound = i;
                while(i <= bound){
                    bound = Math.max(bound, arr[i]);
                    i++;
                }
                max++;
            }
            return max;
        }
    }
    
  • 相关阅读:
    deepin 系统更新命令
    安装mongdb
    读model所得
    上周某一天
    在项目中直接执行里面的文件
    数据库(六)
    数据库(五)
    数据库(四)
    数据库(三)
    数据库(二)
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13074792.html
Copyright © 2011-2022 走看看