[Easy] 手寫 inRange

2024年3月8日

💎 加入 E+ 成長計畫 如果你喜歡我們的內容,歡迎加入 E+,獲得更多深入的軟體前後端內容

題目描述

請實作一個函式 inRange 。此函式接受三個參數:

  • value:要檢查的數值
  • start:範圍的下限 (範圍包含 start),預設為 0
  • end:範圍的上限 (範圍不包含 end)

在實作時,要同時考量以下條件:

  • 預設行為:如果僅提供兩個參數,則第二個參數被視為 end,而 start 此時預設為 0,這樣會讓使用該函式的人,在正數範圍內能更簡易地使用
  • 負數範圍:如果 start 大於 endinRange 會交換參數以正確處理負數範圍,確保在正負數都能被處理
  • 輸出:inRange 函式輸出會是一個 Boolean
inRange(3, 2, 4); // => true
inRange(4, 8); // => true
inRange(4, 2); // => false
inRange(2, 2); // => false
inRange(1.2, 2); // => true

本題解答

以下是本題的解答,詳細解題思路可以在 E+ 成長計畫 看到。如果想練習更多題目,推薦可以到 GreatFrontEnd 上練習。

解法

function inRange(value, start, end = 0) {
  return value >= Math.min(start, end) && value < Math.max(start, end);
}
🧵 如果你想收到最即時的內容更新,可以在 FacebookInstagram 上追蹤我們