陣列入門題 使否為單調數列 Monotonic Array Leetcode #896

閱讀時間約 2 分鐘
raw-image

這題的題目在這裡:

題目敘述

題目會給一個輸入陣列,要求我們判斷所有的數字是否構成一組單調數列

也就是全部的數字構成一條單調遞增數列(逐漸變大)
或者一條單調遞減數列(逐漸變小)?


測試範例

Example 1:

Input: nums = [1,2,2,3]
Output: true

Example 2:

Input: nums = [6,5,4,4]
Output: true

Example 3:

Input: nums = [1,3,2]
Output: false

 


約束條件

Constraints:

  • 1 <= nums.length <= 105
  • -105 <= nums[i] <= 105

演算法

這題依照定義出發即可。

從左到右逐項檢查,如果發現遞增的某兩項,就把遞增的flag設成True。
同樣道理,如果發現遞減的某兩項,就把遞減的flag設成True。

只要發現 遞增 或 遞減 同時為True,代表無法構成一條單調數列返回False

反之,代表可以,返回True

raw-image



程式碼

class Solution:
 def isMonotonic(self, nums: List[int]) -> bool:
  n = len(nums)
  
  increasing = False
  decreasing = False

  for i in range(n-1):

   if nums[i] < nums[i+1]:
    increasing = True
   
   elif nums[i] > nums[i+1]:
    decreasing = True
   
   # Both increasing and decreasing exist, it is not monotonic series
   if increasing and decreasing:
    return False

  return True



複雜度分析

時間複雜度:

O( n ) 從左到右掃描一遍,每個數字拿去和後面的數字比大小。

空間複查度:

O( 1 ) 只有用到固定大小的臨時變數,占用的記憶體空間為常數級別O(1)。


Reference:

[1] Python O( n ) sol. based on generator expression. 80%+ [ With explanation ] - Monotonic Array - LeetCode

85會員
425內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
發表第一個留言支持創作者!
題目會給我們一個陣列,分別代表高低各不同的隔板高度,問我們從降雨之後,最多可以儲存多少水量?
雖然表面是一道移除元素的題目,但實際上考的還是搬移。 題目要求的是把val目標值移除,等價於 把非目標值的搬到前面,並且回傳這些剩下來的元素個數(也就是 陣列裡面,非目標值的元素總數​)。 請看下方範例,會更好理解。
題目會給定我們一個陣列,要求我們重新安排順序,把等於零的數字搬到後面。 同時必須保持原本數字的前後相對次序。
題目會給定一個陣列,要求我們把裡面的數字依照奇偶數去排序, 偶數的排在前面,奇數的排在後面。
題目會給定一個2D 二維的矩陣,矩陣內的元素值代表對應的高度,要求我們找出相對最高點,也就是(大樓)高度大於N4 東、南、西、北 四個鄰居的索引值。 題目保證矩陣內相鄰的元素值都不相同,也又是相鄰的兩兩相比較,一定有一個比較高,有一個比較矮。
題目會給定一個陣列,陣列裡面的元素分布就像一座山峰。 最大值的左邊都是上坡段,最大值的右邊都是下坡段。 要求我們找出陣列裡面的絕對極大值(absolute max value)所在的陣列索引
題目會給我們一個陣列,分別代表高低各不同的隔板高度,問我們從降雨之後,最多可以儲存多少水量?
雖然表面是一道移除元素的題目,但實際上考的還是搬移。 題目要求的是把val目標值移除,等價於 把非目標值的搬到前面,並且回傳這些剩下來的元素個數(也就是 陣列裡面,非目標值的元素總數​)。 請看下方範例,會更好理解。
題目會給定我們一個陣列,要求我們重新安排順序,把等於零的數字搬到後面。 同時必須保持原本數字的前後相對次序。
題目會給定一個陣列,要求我們把裡面的數字依照奇偶數去排序, 偶數的排在前面,奇數的排在後面。
題目會給定一個2D 二維的矩陣,矩陣內的元素值代表對應的高度,要求我們找出相對最高點,也就是(大樓)高度大於N4 東、南、西、北 四個鄰居的索引值。 題目保證矩陣內相鄰的元素值都不相同,也又是相鄰的兩兩相比較,一定有一個比較高,有一個比較矮。
題目會給定一個陣列,陣列裡面的元素分布就像一座山峰。 最大值的左邊都是上坡段,最大值的右邊都是下坡段。 要求我們找出陣列裡面的絕對極大值(absolute max value)所在的陣列索引
你可能也想看
Google News 追蹤
Thumbnail
接下來第二部分我們持續討論美國總統大選如何佈局, 以及選前一週到年底的操作策略建議 分析兩位候選人政策利多/ 利空的板塊和股票
Thumbnail
🤔為什麼團長的能力是死亡筆記本? 🤔為什麼像是死亡筆記本呢? 🤨作者巧思-讓妮翁死亡合理的幾個伏筆
不管在星星兒進行適應轉變的過程而引導,甚至在星星兒得不到具體明確的回應,要是因此霸凌星星兒,務必列入永無止盡的黑名單。 防止星星兒的二次傷害 在星星兒的立場,因為知人知面不知心,導致星星兒無法判斷人心的善惡。 畢竟,人很複雜。 當然,真要說,有星星兒在適應轉變,而無法適應轉變,反而出現嚴重傷
Thumbnail
題目會給定我們一個輸入陣列,要求我們計算好配對的數目有多少個? 好配對的定義: 兩個數字相同,但是陣列索引一個在前,一個在後。 nums[i] == nums[j] and i < j. 這樣 (i, j) 就稱為一組好配對。
Thumbnail
題目會給定我們一個陣列,陣列長度為n。 要求我們找出裡面出現次數超過 n / 3次的數字。
Thumbnail
題目會給定我們一個陣列,要求我們找出裡面出現次數最多的數字。 出現次數最多的數字也就是我們在統計上所謂的 眾數 mode
Thumbnail
題目會給一個輸入陣列,要求我們判斷所有的數字是否構成一組單調數列。 也就是全部的數字構成一條單調遞增數列(逐漸變大), 或者一條單調遞減數列(逐漸變小)?
Thumbnail
👨‍💻簡介 陣列就像是一個儲存相同類型資料的容器,你可以想像成裝滿了一樣東西的盒子,每個東西都叫做陣列元素。這種類型可以是基本的,像是整數或字串,也可以是你自己定義的型別。不過陣列有個限制,就是大小一旦確定就無法改變。在Go語言裡,陣列的長度也是型別的一部分。
Thumbnail
先天八卦,「震巽为一炁[qì]」,震一阳生,巽一阴生,故为「一炁」。希伯来字母第一个字母alef:א。 意思是善恶分开,事情的开始。上帝是第一推动,上帝创造善的同时,对称的创造了恶。律法区分善恶,意味着善恶是对称的,善恶都是上帝创造的,都是从上帝而来的。上主是一,善恶是上主的两种力量,诫命是让选民去
Thumbnail
震為雷 上下皆震卦,表示接二連三的打雷 打雷就會怕怕,但克服怕怕的恐懼便是不驚慌失措 這是我第四個我每日卦裡抽到的純卦 所謂的純卦就是上下皆是八卦的同一卦 比如我已經抽過的 乾為天 就是上下都是乾卦所以你會看到6橫一, 艮為山就是上下都是艮卦,離為火就是上下都是離卦 當然因為我是抽每日的,所以算是一
Thumbnail
莫瑞泰斯皇家美術館積極邀請大家「交出你的珍珠耳環少女!」,提供自己受到《戴著珍珠耳環的少女》啟發的作品,任何形式、任何媒材,通通都可以!
Thumbnail
接下來第二部分我們持續討論美國總統大選如何佈局, 以及選前一週到年底的操作策略建議 分析兩位候選人政策利多/ 利空的板塊和股票
Thumbnail
🤔為什麼團長的能力是死亡筆記本? 🤔為什麼像是死亡筆記本呢? 🤨作者巧思-讓妮翁死亡合理的幾個伏筆
不管在星星兒進行適應轉變的過程而引導,甚至在星星兒得不到具體明確的回應,要是因此霸凌星星兒,務必列入永無止盡的黑名單。 防止星星兒的二次傷害 在星星兒的立場,因為知人知面不知心,導致星星兒無法判斷人心的善惡。 畢竟,人很複雜。 當然,真要說,有星星兒在適應轉變,而無法適應轉變,反而出現嚴重傷
Thumbnail
題目會給定我們一個輸入陣列,要求我們計算好配對的數目有多少個? 好配對的定義: 兩個數字相同,但是陣列索引一個在前,一個在後。 nums[i] == nums[j] and i < j. 這樣 (i, j) 就稱為一組好配對。
Thumbnail
題目會給定我們一個陣列,陣列長度為n。 要求我們找出裡面出現次數超過 n / 3次的數字。
Thumbnail
題目會給定我們一個陣列,要求我們找出裡面出現次數最多的數字。 出現次數最多的數字也就是我們在統計上所謂的 眾數 mode
Thumbnail
題目會給一個輸入陣列,要求我們判斷所有的數字是否構成一組單調數列。 也就是全部的數字構成一條單調遞增數列(逐漸變大), 或者一條單調遞減數列(逐漸變小)?
Thumbnail
👨‍💻簡介 陣列就像是一個儲存相同類型資料的容器,你可以想像成裝滿了一樣東西的盒子,每個東西都叫做陣列元素。這種類型可以是基本的,像是整數或字串,也可以是你自己定義的型別。不過陣列有個限制,就是大小一旦確定就無法改變。在Go語言裡,陣列的長度也是型別的一部分。
Thumbnail
先天八卦,「震巽为一炁[qì]」,震一阳生,巽一阴生,故为「一炁」。希伯来字母第一个字母alef:א。 意思是善恶分开,事情的开始。上帝是第一推动,上帝创造善的同时,对称的创造了恶。律法区分善恶,意味着善恶是对称的,善恶都是上帝创造的,都是从上帝而来的。上主是一,善恶是上主的两种力量,诫命是让选民去
Thumbnail
震為雷 上下皆震卦,表示接二連三的打雷 打雷就會怕怕,但克服怕怕的恐懼便是不驚慌失措 這是我第四個我每日卦裡抽到的純卦 所謂的純卦就是上下皆是八卦的同一卦 比如我已經抽過的 乾為天 就是上下都是乾卦所以你會看到6橫一, 艮為山就是上下都是艮卦,離為火就是上下都是離卦 當然因為我是抽每日的,所以算是一
Thumbnail
莫瑞泰斯皇家美術館積極邀請大家「交出你的珍珠耳環少女!」,提供自己受到《戴著珍珠耳環的少女》啟發的作品,任何形式、任何媒材,通通都可以!