首頁  >  文章  >  後端開發  >  三步驟中最大和最小值之間的最小差異

三步驟中最大和最小值之間的最小差異

WBOY
WBOY原創
2024-07-18 22:44:211179瀏覽

Minimum Difference Between Largest and Smallest Value in Three Moves

1509。三步驟中最大值和最小值之間的最小差異

給你一個整數數組 nums。

一步即可選擇 nums 的一個元素,並將其變更為任意值

傳回nums的最大值和最小值之間的最小差值執行最多三步後.

範例1:

  • 輸入: nums = [5,3,2,4]
  • 輸出: 0
  • 說明:我們最多可以進行 3 步驟。
  In the first move, change 2 to 3. nums becomes [5,3,3,4].
  In the second move, change 4 to 3. nums becomes [5,3,3,3].
  In the third move, change 5 to 3. nums becomes [3,3,3,3].
  After performing 3 moves, the difference between the minimum and maximum is 3 - 3 = 0.

範例2:

  • 輸入: nums = [1,5,0,10,14]
  • 輸出: 1
  • 說明:我們最多可以進行 3 步驟。
  In the first move, change 5 to 0. nums becomes [1,0,0,10,14].
  In the second move, change 10 to 0. nums becomes [1,0,0,0,14].
  In the third move, change 14 to 1. nums becomes [1,0,0,0,1].
  After performing 3 moves, the difference between the minimum and maximum is 1 - 0 = 1.
  It can be shown that there is no way to make the difference 0 in 3 moves.

範例 3:

  • 輸入: nums = [3,100,20]
  • 輸出: 0
  • 說明:我們最多可以進行 3 步驟。
  In the first move, change 100 to 7. nums becomes [3,7,20].
  In the second move, change 20 to 7. nums becomes [3,7,7].
  In the third move, change 3 to 7. nums becomes [7,7,7].
  After performing 3 moves, the difference between the minimum and maximum is 7 - 7 = 0.

約束:

  • 1 5
  • -109 9

解:

class Solution {

    /**
     * @param Integer[] $nums
     * @return Integer
     */
    function minDifference($nums) {
        $n = count($nums);

        // If the array has 4 or fewer elements, the difference is zero because we can remove all but one element.
        if ($n <= 4) {
            return 0;
        }

        // Sort the array to facilitate the calculation of differences after removals.
        sort($nums);

        // We consider removing 0, 1, 2, or 3 elements from the start or the end.
        // Calculate the differences:
        // 1. Remove 3 from start: nums[n-1] - nums[3]
        // 2. Remove 2 from start, 1 from end: nums[n-2] - nums[2]
        // 3. Remove 1 from start, 2 from end: nums[n-3] - nums[1]
        // 4. Remove 3 from end: nums[n-4] - nums[0]
        $differences = [
            $nums[$n - 1] - $nums[3],
            $nums[$n - 2] - $nums[2],
            $nums[$n - 3] - $nums[1],
            $nums[$n - 4] - $nums[0]
        ];

        // Return the minimum difference.
        return min($differences);
    }
}

聯絡連結

  • 領英
  • GitHub

以上是三步驟中最大和最小值之間的最小差異的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn