程序在Python中最多更新三次元素后查找最大值和最小值的最小差异
假设我们有一个称为nums的数字列表,现在考虑一个可以将元素更新为任何值的操作。我们最多只能执行3种此类操作,我们必须找到以num为单位的最大值和最小值之间的最小差值。
因此,如果输入类似于nums=[2,3,4,5,6,6,7],则输出将为2,因为我们可以将列表更改为[4,3,4,5,5,4,4]然后5-3=2。
为了解决这个问题,我们将遵循以下步骤-
如果nums<=4,则
返回0
n:=nums的大小
排序列表编号
返回范围0到3中所有i的nums[n-4+i]-nums[i]之间的差的最小值
让我们看下面的实现以更好地理解-
示例
class Solution:
def solve(self, nums):
if len(nums) <= 4:
return 0
nums.sort()
return min(nums[-4 + i] - nums[i] for i in range(4))
ob = Solution()nums = [2, 3, 4, 5, 6, 7] print(ob.solve(nums))输入项
[2, 3, 4, 5, 6, 7]
输出结果
2
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短