面试题 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};
}
}
心之所向,素履以往 生如逆旅,一苇以航

浙公网安备 33010602011771号