【LeetCode】1752. 检查数组是否经排序和轮转得到

news2025/1/13 9:48:43

题目描述

给你一个数组 nums 。nums 的源数组中,所有元素与 nums 相同,但按非递减顺序排列。
如果 nums 能够由源数组轮转若干位置(包括 0 个位置)得到,则返回 true ;否则,返回 false 。
源数组中可能存在 重复项 。
注意:我们称数组 A 在轮转 x 个位置后得到长度相同的数组 B ,当它们满足 A[i] == B[(i+x) % A.length] ,其中 % 为取余运算。

示例 1:

输入:nums = [3,4,5,1,2]
输出:true
解释:[1,2,3,4,5] 为有序的源数组。
可以轮转 x = 3 个位置,使新数组从值为 3 的元素开始:[3,4,5,1,2] 。

示例 2:

输入:nums = [2,1,3,4]
输出:false
解释:源数组无法经轮转得到 nums 。

示例 3:

输入:nums = [1,2,3]
输出:true
解释:[1,2,3] 为有序的源数组。
可以轮转 x = 0 个位置(即不轮转)得到 nums 。

提示:

1 <= nums.length <= 100
1 <= nums[i] <= 100

方法一:我的解法

class Solution {
public:
    bool check(vector<int>& nums) {
        int pos = 0;
        int n = nums.size();
        vector<int> numsOrigin(n);

        // 保存默认数组
        for(int i=0; i<n ; i++)
            numsOrigin[i] = nums[i];
            
        // nums为原数组 
        sort(nums.begin(), nums.end()); // 默认升序

		// 确定目标元素的偏移量
        for(int i=0; i<n; i++){
            // 条件1:当前数字与原数组不匹配
            // 条件2:如果有若干连续的数字,考虑最后一个
            if(numsOrigin[i] != nums[i] && numsOrigin[i] != numsOrigin[(i+1) % n]){
                // 目标元素
                int flag = numsOrigin[i];
                for(int j=0; j<n; j++){
                    // 条件1:在排序数组中找到目标元素
                    // 条件2:如果有若干连续数字,考虑最后一个
                    if(flag == nums[j] && nums[j] != nums[(j + 1)%n]){
                        // 确定偏移位置
                        pos = (j - i + n) % n; 
                        break;
                    }
                }
                break;
            }
        }
        for(int i=0; i<n; i++){
            if(numsOrigin[i] != nums[(i + pos) % n])   return false;
        }
        return true;
    }
};

方法二:优秀题解

class Solution {
public:
    bool check(vector<int>& nums) {
        int cnt = 0; // 记录非递增情况出现的次数
        int n = nums.size();
        for(int i=0; i<n-1; i++){
            if(nums[i] > nums[i+1]) cnt ++;
        }
        // nums已经是非递减数组,说明与原数组相同
        if(cnt == 0)    return true;
        // 仅发生了一次非递增
        // 并且第一个元素大于最后一个元素,说明首尾元素也是非递减的
        else if(cnt == 1 && nums[0] >= nums[n-1])   return true;
        // 不止一次非递增
        else return false;
    }
};

心得

  • 这道题是11.27的每日一题,那天出去玩了,没做出来,今天补一下。这道题是简单题,但我的解法略微显得复杂,甚至我提交了很多次,最后在卡测试点才通过的,但是还是记录一下,更推荐看解法二。
  • 解法一:常规解法

  • 思路:由于 原数组是一个 递增 数组,因此我对 nums 进行了 sort 排序得到了原数组,之后就是确定一个 目标元素 ,确定目标元素在 「给定数组」 和 「原数组」之间的偏移量,最后在给定数组中遍历偏移量即可。

  • 重点在于 如何确定 目标元素 和 偏移量

    • 一开始我只考虑到了 条件1:找到第一个在「原数组」和「给定数组」中不同的元素
      但是这个考虑不全面, 比如:
      • nums = [4, 5, 7, 7, 9, 9, 10, 10, 3, 4],
        这个数组的原数组是 [3, 4, 4, 5, 7, 7, 9, 9, 10, 10]
      • 第一个不同的元素是 nums 中的第一个 4 ,但是很明显,我们可以发现第一个 4 应该对应的是 原数组中的第二个 4,然而我一开始给出的条件只能将第一个 4 对应到 原数组的第一个 4。
    • 因此,我在确定偏移量的部分加上了 条件2:如果有若干连续的数字,考虑最后一个
      此时,上面的例子就能正确通过了,我们也确定了 目标元素
    • 然而此时出现另外一种情况,比如:
      • nums = [5,5,6,6,6,9,1,2],
        这个数组的原数组是 [1,2,5,5,6,6,6,9]
      • 第一个不同的元素应该是 第一个 5 , 如果按照上面的两个逻辑,此时的第一个 5 会默认匹配到最后一个 5 ,那显然是不正确的,因此我在确定目标元素的部分加上了 条件2:如果有若干连续的数字,考虑最后一个。此时,这个例子的目标元素就是第二个 5 。

    综上所述,通过各两个条件,我们就能确定目标元素偏移量

  • 方法二:
  • 思路:对于 True,其实有两种情况:
    • 情况一: 如果给定数组已经是递增的,说明原数组轮转 0 个位置就可以得到给定数组;
    • 情况二: 如果在 nums 数组中,仅仅有一次「非递增」的情况发生,那么需要满足 nums[0] >= nums[nums.length -1]

在这里插入图片描述

参考资料:

  1. 【爪哇缪斯】图解LeetCode

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/45301.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

怎么提高外贸开发信的回复率?

写客户开发信是每个外贸人都必备的技能。对于成本预算小的企业来讲&#xff0c;开发信是性价比非常高的一种方式。但是&#xff0c;很多人在写完开发信之后并没有收获到比较好的回复效果&#xff0c;可能是因为他们没有把握写开发信的技巧。怎么提高外贸开发信的回复率&#xf…

挖掘数据价值,华为云大数据BI解决方案有绝招

在没有接触电子商务时&#xff0c;就一直很好奇&#xff0c;他们是怎么知道我需要什么并及时推送给我的&#xff0c;直到后来自己也开始做电商的时候&#xff0c;才知道原来电子商务必不可少的是大数据分析方案。在这里我强烈给同业者们安利一下华为云的大数据BI解决方案&#…

大厂都在用MyBatis,跳槽的时候MyBatis更是面试必问的内容,那你对于MyBatis又掌握了多少呢?这份MyBatis源码解析值得拥有!

MyBatis作为一个流行的半自动ORM框架&#xff0c;里面融合了许多优秀的设计理念&#xff0c;分析其源码骨架能够帮你建立良好的项目设计经验。由于其比较复杂&#xff0c;我会分成几篇来讲&#xff0c;一起踏上征服的旅程吧&#xff01; 首先把MyBatis源码包导入到idea&#x…

PC_非连续内存分配方式@分页存储管理@地址变换机构@快表@有效访存时间

文章目录非连续内存分配方式&#x1f388;分页存储管理基本分页存储管理页面和页面大小分块和碎片逻辑地址结构页表页表项结构页表项和地址比较&#x1f388;页表项地址地址变换机构基本地址变换机构结构图映射过程Note:页表长度页表项长度页表大小例小结ref具有快表的地址变换…

xxl-job安装部署

一、简介 XXL-JOB是一个分布式任务调度平台&#xff0c;其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线&#xff0c;开箱即用。 中文文档English Documentation 二、安装 xxl-job需要的提前安装好以下环境&#xff1a;jdk、m…

A-Level物理例题解析及练习Projectile Motion

今日知识点&#xff1a;Magnetic Force例题 Q: A proton p and an electron e, with the same velocity, enter a magnetic field which is perpendicular to the direction of their motion. The field acts into the page. Which of the following diagrams best represents …

Spire.XLS for Java 12.11.8 Excel to PDF bug Fix

谷歌找破解版Spire.XLS for Java is a professional Java Excel API that enables developers to create, manage, manipulate, convert and print Excel worksheets without using Microsoft Office or Microsoft Excel. Spire.XLS for Java supports both for the old Excel …

Spark系列之Spark的Shuffle详解及相关参数调优

title: Spark系列 第七章 Spark的Shuffle详解及相关参数调优 ​ 大多数Spark作业的性能主要就是消耗在了shuffle环节&#xff0c;因为该环节包含了大量的磁盘IO、序列化、网 络数据传输等操作。因此&#xff0c;如果要让作业的性能更上一层楼&#xff0c;就有必要对shuffle过程…

数图互通高校房产管理——公房管理功能详解

数图互通房产管理系统在这方面做得比较全面&#xff1b; 公用房管理 1 房屋档案 可维护校区信息、公房的楼栋信息、公房的房间信息&#xff0c;记录校区的名称、建成年份、占地面积、建筑面积等基本信息。记录楼栋的编号、名称、建筑面积、使用面积等基本信息&#xff0c;同…

[附源码]计算机毕业设计springboot超市商品管理

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

企业研发数据:省级工业企业研发费用、企业非真实研发支出原始数据加计算stata do代码两大维度指标

1、省级工业企业研发费用 1、数据来源&#xff1a;Wind 2、时间跨度&#xff1a;2008-2019年 3、区域范围&#xff1a;全国31省(区分了东中西部地区&#xff09; 4、指标说明&#xff1a; 包含如下指标&#xff1a; 省级规模以上工业企业R&D经费 省级规模以上工业企…

Kotlin高仿微信-第8篇-单聊

Kotlin高仿微信-项目实践58篇详细讲解了各个功能点&#xff0c;包括&#xff1a;注册、登录、主页、单聊(文本、表情、语音、图片、小视频、视频通话、语音通话、红包、转账)、群聊、个人信息、朋友圈、支付服务、扫一扫、搜索好友、添加好友、开通VIP等众多功能。 Kotlin高仿…

http和dubbo接口调用主动设置超时时间

http接口超时方案 方案1&#xff1a;多个resttemplate&#xff0c;不同超时时间的使用不同的template&#xff0c;优点&#xff1a;简单&#xff0c;扩展起来复制粘贴&#xff0c;缺点&#xff1a;代码冗余&#xff0c;多个template占用内存不够优雅 方案2&#xff1a;单个res…

MySQL事务和锁

目录 1、四大特性 2、事务引发的问题 3、事务控制演进 3.1、排队 3.2、排它锁 3.3、读写锁 3.4、MVCC 4、事务的隔离级别 4.1、四种隔离级别 4.2、事务隔离级别和锁的关系 4.3、MySQL隔离级别控制 5、锁机制和实战 5.1、锁分类 5.1.1、按操作粒度分类 5.1.2、按…

CDMP选修课都有什么?

大家都知道CDMP认证考试有四个级别。分别是A级&#xff08;基础级&#xff09;P级&#xff08;实践级&#xff09;M级&#xff08;专业级&#xff09;F级&#xff08;大师级&#xff09;。级别越高&#xff0c;考试难度就越大&#xff0c;分数比例要求也更高&#xff0c;相对应…

在Linux命令行中查找空目录

在 Linux 系统中&#xff0c;出现空的目录这是很正常的事情&#xff0c;而且&#xff0c;也是有办法一次性把它们都找出来的。 但是&#xff0c;仅仅列出空目录并不是我们的目的&#xff0c;我们今天了解一下如何删除这些空的目录。 在Linux中查找空目录 查找空目录&#xf…

ThinkPHP5文档学习——配置

文章目录一、配置目录二、配置格式PHP数组定义其它格式的支持二级配置三、配置加载惯例配置应用配置拓展配置场景配置四、读取配置参数五、动态配置设置配置参数六、独立配置独立配置文件V5.0.1版本已经废除该写法自动读取扩展配置七、配置作用域八、环境变量配置一、配置目录 …

语文课内外杂志语文课内外杂志社语文课内外杂志社2022年第14期目录

幼儿教育《语文课内外》投稿&#xff1a;cn7kantougao163.com 家园协同视域下幼儿心理危机的预防与干预对策 曹锭1-3 幼小衔接阶段幼儿时间观念的培养对策 陈晶晶4-6 有效支持 助力幼儿在书海中徜徉 胡玲珊7-9 东西部幼儿园结对帮扶,助力乡村教育扶贫——以广州市人民政府机关幼…

虹科分享|终端安全防护|网络安全术语列表(二)

如果你的工作或者生活与网络安全有关&#xff0c;你就知道它使用了自己独特的、不断发展的语言。术语和缩略语受到网络安全专家的喜爱。因此&#xff0c;我们创建了一个全面的网络安全词汇表&#xff0c;解释了常用的网络安全术语、短语和技术。我们设计此列表是为了揭开安全专…

[附源码]Python计算机毕业设计Django贷款申请审核管理系统论文

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;我…