LeetCode 每日一题笔记 日期:2026.05.23 题目:1752. 检查数组是否经排序和轮转得到
LeetCode 每日一题笔记
0. 前言
- 日期:2026.05.23
- 题目:1752. 检查数组是否经排序和轮转得到
- 难度:简单
- 标签:数组
1. 题目理解
问题描述:
给你一个数组nums。其源数组是按非递减顺序排列的nums本身。判断nums是否可以由源数组经过若干次轮转(包括0次)得到。
示例:
输入:
nums = [3,4,5,1,2]
输出:true
解释:由有序数组[1,2,3,4,5]轮转2次得到。
输入:
nums = [2,1,3,4]
输出:false
解释:无法由有序数组轮转得到。
2. 解题思路
核心观察
- 有序数组轮转后,数组中下降的次数(即
nums[i] > nums[i+1]的情况)最多出现一次; - 包括首尾元素的比较(即
nums[n-1]和nums[0]),总共下降次数 ≤ 1 时,即为合法的轮转数组。
算法步骤
- 遍历数组,统计相邻元素(包括首尾)中
nums[i] > nums[(i+1)%n]的次数; - 若次数 ≤ 1,则返回
true;否则返回false。
3. 代码实现
classSolution{publicbooleancheck(int[]nums){intcount=0;intn=nums.length;for(inti=0;i<n;i++){if(nums[i]>nums[(i+1)%n]){count++;}}returncount<=1;}}4. 代码优化说明
减少分支判断,直接在循环中完成计数和提前终止,逻辑更紧凑:
classSolution{publicbooleancheck(int[]nums){intcount=0;intn=nums.length;for(inti=0;i<n;i++){if(nums[i]>nums[(i+1)%n]&&++count>1){returnfalse;}}returntrue;}}5. 复杂度分析
- 时间复杂度:O(n)O(n)O(n),遍历一次数组即可完成统计。
- 空间复杂度:O(1)O(1)O(1),仅使用常数级额外变量。
6. 总结
- 核心思路:统计下降次数,利用有序数组轮转的特性,下降次数不超过1次即为合法;
- 优化后代码通过提前终止减少不必要的遍历,同时保持逻辑简洁;
- 本题关键是理解有序数组轮转后的局部有序性,以及下降次数的判定条件。
