文章目录

  • 1. 题目
  • 2. 解题

1. 题目

给你一个数组 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 。示例 4:
输入:nums = [1,1,1]
输出:true
解释:[1,1,1] 为有序的源数组。
轮转任意个位置都可以得到 nums 。示例 5:
输入:nums = [2,1]
输出:true
解释:[1,2] 为有序的源数组。
可以轮转 x = 5 个位置,使新数组从值为 2 的元素开始:[2,1] 。提示:
1 <= nums.length <= 100
1 <= nums[i] <= 100

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/check-if-array-is-sorted-and-rotated
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 计算下降的次数
class Solution {public:bool check(vector<int>& nums) {int count = 0, n = nums.size();for(int i = 0; i < n; ++i){if(nums[i] > nums[(i+1)%n])count++;if(count > 1)return false;}return true;}
};

4 ms 8 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

LeetCode 1752. 检查数组是否经排序和轮转得到相关推荐

  1. LeetCode简单题之检查数组是否经排序和轮转得到

    题目 给你一个数组 nums .nums 的源数组中,所有元素与 nums 相同,但按非递减顺序排列. 如果 nums 能够由源数组轮转若干位置(包括 0 个位置)得到,则返回 true :否则,返回 ...

  2. LeetCode 1497. 检查数组对是否可以被 k 整除(余数配对)

    1. 题目 给你一个整数数组 arr 和一个整数 k ,其中数组长度是偶数,值为 n . 现在需要把数组恰好分成 n / 2 对,以使每对数字的和都能够被 k 整除. 如果存在这样的分法,请返回 Tr ...

  3. LeetCode 1497. 检查数组对是否可以被 k 整除

    public static boolean canArrange(int[] arr, int k) {int[] h = new int[k];for(int num : arr){int mod ...

  4. 2021-12-12 Leetcode 1497.检查数组对是否可以被 k 整除

    第一种方法:尝试数字两两组合,看是否为 k 的倍数,写不出来 第二种方法(参考别人的):将每个数字对 k 取模,放入相应的桶里,看 1 与 k-1 这样的队伍的个数是否相同,如果是就是正确的,不是就是 ...

  5. Leetcode面试题 10.01. 合并排序的数组(C语言)

    Leetcode面试题 10.01. 合并排序的数组(C语言) 题目: 给定两个排序后的数组 A 和 B,其中 A 的末端有足够的缓冲空间容纳 B. 编写一个方法,将 B 合并入 A 并排序.初始化 ...

  6. LeetCode高频题33. 搜索旋转排序数组

    LeetCode高频题33. 搜索旋转排序数组 提示:本题是系列LeetCode的150道高频题,你未来遇到的互联网大厂的笔试和面试考题,基本都是从这上面改编而来的题目 互联网大厂们在公司养了一大批A ...

  7. 【LeetCode】1609. 奇偶树、1122. 数组的相对排序

    作者:小卢 专栏:<Leetcode> 喜欢的话:世间因为少年的挺身而出,而更加瑰丽.                                  --<人民日报> 16 ...

  8. 【Leetcode -1609.奇偶树 -1122.数组的相对排序】

    Leetcode Leetcode -1609.奇偶树 Leetcode -1122.数组的相对排序 Leetcode -1609.奇偶树 题目:如果一棵二叉树满足下述几个条件,则可以称为 奇偶树 : ...

  9. LeetCode实战:数组中的第K个最大元素

    背景 为什么你要加入一个技术团队? 如何加入 LSGO 软件技术团队? 我是如何组织"算法刻意练习活动"的? 为什么要求团队的学生们写技术Blog 题目英文 Find the kt ...

最新文章

  1. 【降维解法:最大字段和-最大子矩阵和-最终版最大子长方体和】【UVA10755】Garbage Heap...
  2. MySQL中TIMESTAMPDIFF和TIMESTAMPADD函数
  3. 2019 GDUT Rating Contest II : Problem G. Snow Boots
  4. C++ Primer Plus学习:第十章
  5. centos7.3安装elasticsearch-head
  6. 有源降噪装置专利(转)
  7. 如何判断微信内置浏览器(JS PHP)
  8. 史上最容易理解的暴力递归和动态规划~~
  9. 虚拟专题:知识图谱 | 基于网络防御知识图谱的0day攻击路径预测方法
  10. Qt之模式、非模式、半模式对话框
  11. 基于HTML5坦克大战游戏简化版
  12. python—符号 | ^的使用
  13. ubuntu12.04 安装 coreseek 4.1beta (转)
  14. python常用的几种字符串替换函数strip、replace、sub
  15. matlab node._matlab调用ansys
  16. PS CC 2014破解版
  17. 如何用圆弧插补法画一个圆
  18. 企业支付宝 异名网银u盾快速充值功能开通方式(支付宝企业商户资金充值方法)
  19. 过程控制第四章到第六章
  20. es6 箭头函数 模板字符串 点点点运算符

热门文章

  1. Django REST framework 源码解析
  2. mysql 集群架构_mysql企业常用集群架构
  3. 编写的windows程序,崩溃时产生crash dump文件的办法
  4. 包r语言_R语言入门之寻找你的R包
  5. linux内核的I2C子系统详解4——i2c-s3c2410.c文件中的adapter、algorithm
  6. cocos2dx 3.4 截图代码
  7. 201673020127 词频统计软件项目报告
  8. shell脚本while read line的使用
  9. Theano 更多示例
  10. Codis的源码编译生成tar包