【一天一道Leetcode】单调数列
01
题目描述
题目描述:
如果数组是单调递增或单调递减的,那么这个数组就是单调的数组。
如果对于所有 i <= j,A[i] <= A[j],
那么数组 A 是单调递增的。
如果对于所有 i<= j,A[i]> = A[j],
那么数组 A 是单调递减的。
当给定的数组 A是单调数组时返回 true,
否则返回 false。
示例:
输入:[1,2,2,3]
输出:true
输入:[6,5,4,4]
输出:true
输入:[1,3,2]
输出:false
02
既然需要判断数组是否单调递增或者单调递减
则可以先将原数组进行升序或者降序排序,再将排序后的数组与原数组进行比较,判断是否相等,如果相等则输出true,不相等则输出false。
这里引入sorted()的函数概念
sorted()函数是Python3的内置函数
sorted()函数的主要用法是对所有可迭代的对象进行排序操作。
如下所示:
sorted(iterable, key=None, reverse=False)
iterable:可迭代对象。
key:主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
reverse:排序规则,reverse= True 降序 , reverse = False 升序(默认)。
sorted()函数的实际用法如下所示:
A=[8,5,5,9,1]
# 默认为升序
sorted(A)=[1,5,5,8,9]
# 此时为降序
sorted(A, reverse = True)=[9,8,5,5,1]
由此可以得到本题的解题代码:
class Solution:
def isMonotonic(self, A: List[int]) -> bool:
B=sorted(A)
C=sorted(A,reverse=True)