LeetCode 面试题 16.16. 部分排序

文章目录

一、题目

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

示例:

输入: [1,2,4,7,10,11,7,12,6,7,16,18,19]
输出: [3,9]

提示:

  • 0 <= len(array) <= 1000000

点击此处跳转题目

二、C# 题解

笨蛋方法就是,先排序,然后一个一个比较。

csharp 复制代码
public class Solution {
    public int[] SubSort(int[] array) {
        int[] sorted = new int[array.Length], ans = { -1, -1 };
        Array.Copy(array, sorted, array.Length);
        Array.Sort(sorted);
        for (var i = 0; i < array.Length; i++) {
            if (ans[0] == -1 && array[i] != sorted[i]) ans[0] = i;
            if (ans[1] == -1 && array[^(i + 1)] != sorted[^(i + 1)]) ans[1] = array.Length - i - 1;
        }
        return ans;
    }
}
  • 时间:204 ms,击败 40.00% 使用 C# 的用户
  • 内存:54.22 MB,击败 40.00% 使用 C# 的用户

一次遍历也可以实现,原理是:乱序的左端 > 右边的最小值,乱序的右端 < 左边的最大值。

从左向右遍历,寻找乱序的右端;从右向左遍历,寻找乱序的左端。

⟵ ⟵ ⟵ ⟵ ⟵ ⏞ m i n = 6 { 1 2 4 ⋮ 7 ‾ 10 11 7 12 6 7 ‾ ⋮ 16 18 19 } ⏟ m a x = 12 ⟶ ⟶ ⟶ ⟶ ⟶ \begin{array}{l} \longleftarrow \hspace{1em} \longleftarrow \hspace{1em} \longleftarrow \hspace{1em} \longleftarrow \hspace{1em} \longleftarrow \hspace{0.8em} \overbrace{\hspace{26.5em}}^{min=6}\\ \{\hspace{0.78em} 1 \hspace{2.2em} 2 \hspace{2.25em} 4 \hspace{1.4em} \vdots \hspace{1.4em} \underline{\bold{7}} \hspace{2.1em} 10 \hspace{2.25em} 11 \hspace{2.25em} 7 \hspace{2.1em} 12 \hspace{2.25em} 6 \hspace{2.4em} \underline{\bold{7}} \hspace{1.4em} \vdots \hspace{1.4em} 16 \hspace{2.25em} 18 \hspace{2.25em} 19 \} \\ \hspace{1.2em} \underbrace{\hspace{24.8em} }_{max=12} \hspace{1em} \longrightarrow \hspace{1em} \longrightarrow \hspace{1em} \longrightarrow \hspace{1em} \longrightarrow \hspace{1em} \longrightarrow\\ \end{array} ⟵⟵⟵⟵⟵ min=6{124⋮7101171267⋮161819}max=12 ⟶⟶⟶⟶⟶

  • 时间:184 ms,击败 100.00% 使用 C# 的用户
  • 内存:53.18 MB,击败 80.00% 使用 C# 的用户
相关推荐
却道天凉_好个秋1 分钟前
目标检测算法与原理(三):PyTorch实现迁移学习
pytorch·算法·目标检测
qeen874 分钟前
【数据结构】单链表及双向链表的解析与实现
数据结构·链表
无限进步_19 分钟前
【C++】大数相加算法详解:从字符串加法到内存布局的思考
开发语言·c++·windows·git·算法·github·visual studio
“抚琴”的人21 分钟前
C#上位机工厂模式
开发语言·c#
C+-C资深大佬36 分钟前
C++ 数据类型转换是如何实现的?
开发语言·c++·算法
cwplh39 分钟前
DP 优化二:斜率优化 DP
算法·动态规划
Hcoco_me1 小时前
大模型面试题90:half2,float4这种优化 与 pack优化的底层原理是什么?
人工智能·算法·机器学习·langchain·vllm
浅念-1 小时前
链表经典面试题目
c语言·数据结构·经验分享·笔记·学习·算法
Python算法实战1 小时前
《大模型面试宝典》(2026版) 正式发布!
人工智能·深度学习·算法·面试·职场和发展·大模型
czwxkn2 小时前
数据结构-线性表
数据结构