面试题 16.16. 部分排序

给定一个整数数组,编写一个函数,找出索引m和n,只要将索引区间[m,n]的元素排好序,整个数组就是有序的。注意:n-m尽量最小,也就是说,找出符合条件的最短序列。函数返回值为[m,n],若不存在这样的m和n(例如整个数组是有序的),请返回[-1,-1]。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/sub-sort-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
    public int[] subSort(int[] array) {
        if (array == null || array.length <= 1) {
            return new int[]{-1, -1};
        }
        int left = 0, leftMax = array[0];
        for (int i = 1; i < array.length; ++i) {
            if (array[i] < leftMax) {
                left = i;
            }
            leftMax = Math.max(leftMax, array[i]);
        }
        int right = array.length - 1, rightMin = array[array.length - 1];
        for (int i = array.length - 2; i >= 0; --i) {
            if (array[i] > rightMin) {
                right = i;
            }
            rightMin = Math.min(rightMin, array[i]);
        }
        return left <= right ? new int[]{-1, -1} : new int[]{right, left};
    }
}
posted @ 2022-01-21 13:37  Tianyiya  阅读(29)  评论(0)    收藏  举报