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 时,即为合法的轮转数组。

算法步骤

  1. 遍历数组,统计相邻元素(包括首尾)中 nums[i] > nums[(i+1)%n] 的次数;
  2. 若次数 ≤ 1,则返回 true;否则返回 false

3. 代码实现

java 复制代码
class Solution {
    public boolean check(int[] nums) {
        int count = 0;
        int n = nums.length;
        
        for (int i = 0; i < n; i++) {
            if (nums[i] > nums[(i + 1) % n]) {
                count++;
            }
        }
        return count <= 1; 
    }
}

4. 代码优化说明

减少分支判断,直接在循环中完成计数和提前终止,逻辑更紧凑:

java 复制代码
class Solution {
    public boolean check(int[] nums) {
        int count = 0;
        int n = nums.length;
        for (int i = 0; i < n; i++) {
            if (nums[i] > nums[(i + 1) % n] && ++count > 1) {
                return false;
            }
        }
        return true;
    }
}

5. 复杂度分析

  • 时间复杂度 :O(n)O(n)O(n),遍历一次数组即可完成统计。
  • 空间复杂度 :O(1)O(1)O(1),仅使用常数级额外变量。

6. 总结

  • 核心思路:统计下降次数,利用有序数组轮转的特性,下降次数不超过1次即为合法;
  • 优化后代码通过提前终止减少不必要的遍历,同时保持逻辑简洁;
  • 本题关键是理解有序数组轮转后的局部有序性,以及下降次数的判定条件。
相关推荐
AI科技星12 分钟前
基于32维Cayley_Dickson超复数的全域拓扑统一场论——反重力、真空自持供能、维度瞬移与星际宇宙脑秩序体系
人工智能·学习·算法·机器学习·数据挖掘
aichitang202419 分钟前
数论变换(NTT)
c++·算法·fft·ntt
_olone22 分钟前
AtCoder Beginner Contest 465 D - X to Y
c++·算法
青山木26 分钟前
Hot 100 --- LRU 缓存
java·数据结构·算法·leetcode·链表·缓存·哈希
“码”力全开26 分钟前
ONVIF摄像头接入项目实战记录
人工智能·算法·边缘计算
大明者省33 分钟前
四大模态大模型训练体系全解析(架构+范式+分布式+算力成本·)
笔记·分布式·架构
十月的皮皮39 分钟前
C语言学习学习笔记20260704-中缀表达式求值(双栈法)
c语言·笔记·学习
智者知已应修善业1 小时前
【 LM358AD方波】2024-12-31
驱动开发·经验分享·笔记·硬件架构·硬件工程
什仙1 小时前
电感规格书全部专业术语完整释义(村田原厂标准定义)
笔记·电感器
AI科技星1 小时前
公理化数学化学|48小时确权终稿(完整投产包)
人工智能·数学·算法·重构·拓扑学·乖乖数学·全域数学