找数组中与其他数绝对值差和最小的数_LeetCode刷题DAY 29:转变数组后最接近目标值的数组和...

4a679478841bd95ac5224ce7851f16db.gif戳蓝色字关注我们哟!

难度:中等  关键词:前缀和,单调性

⭐️⭐️⭐️⭐️⭐️

1

 题目描述

给定一个整数数组 arr 和一个目标值 target ,返回一个整数 value ,使得将数组中所有大于 value 的值变成 value 后,数组的和最接近  target (最接近表示两者之差的绝对值最小)如果有多种使得和最接近 target 的方案,请你返回这些整数中的最小值。如输入arr = [4,9,3], target = 10,输出3,输入arr=[60864,25176,27249,21296,20204],target=56803,输出11361。

2

 题解

思路:前缀和,单调性 本题首先要对题目有深入的理解。对于arr[i],数组和S=sum(arr[0:i]+arr[i]*(len(arr)-i)),因此当对arr进行排序后,发现S是关于arr的单调函数,如下图。 6c886c1c8cffdf2cd75117254418f4ea.png (图片来自网络) 因此当出现S>=target时,意味着目标值在(arr[i-1],arr[i]]之间。也就是说在(arr[i-1],arr[i]]之间存在一个数x,使得sum(arr[0:i]+x*(len(arr)-i))=target。此时求出的x可能是小数,因为要求满足条件的最小整数,所以根据小数具体值判断上取整还是下取整即可 (类似四舍五入,但当小数部分是0.5时要下取整。找例子具体计算一下就可以理解) 。如果S始终小于target,则根据题目要求返回arr中的最大值。
class Solution:    def findBestValue(self, arr: List[int], target: int) -> int:        arr.sort()        pre = 0        for i in range(0,len(arr)):            if pre+arr[i]*(len(arr)-i)>=target:                x = (target-pre)/(len(arr)-i)                if x%1>0.5: return ceil(x)                else : return floor(x)            pre += arr[i]        return arr[-1]

往期推荐:

百度地图API调用:正逆地理编码

基于物品的协同过滤python案例演示

图片相似度识别:pHash算法 小案例(五):销量预测(python)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值