1509。三步驟中最大值和最小值之間的最小差異
中
給你一個整數數組 nums。
一步即可選擇 nums 的一個元素,並將其變更為任意值。
傳回nums的最大值和最小值之間的最小差值執行最多三步後.
範例1:
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:
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:
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.
約束:
解:
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); } }
聯絡連結
以上是三步驟中最大和最小值之間的最小差異的詳細內容。更多資訊請關注PHP中文網其他相關文章!