C. Robin Hood in Town思考与理解

文章目录

C. Robin Hood in Town


  • 首先就是得思考一个问题:如何快速找到有多少个数严格小于平均数的一半?答案是显而易见的,二分,所以我们需要进行升序排序
  • 考虑题目给出的特殊情况当n=1或n=2的时候,直接输出-1即可
  • 那么对于可以通过增加x来判断满足最小的x的问题,这里就转换为,如何快速增加x,然后逐一判断这个x所带来的影响?
    • 直接暴力的做法肯定是x从0开始,逐个+1显而易见,这样十分慢
    • 正确的做法是直接使用二分,这里就要考虑这个二分的范围了,最小肯定是0,那么最大是多少?假设n全部放在一个测试用例,那么考虑到最大的数是10**6,n的最大范围2*10**5,如果开始的全部的n都是1,那么我们得将一半的数全部变为最大也就是10**11
python 复制代码
import bisect
# 二分+二分的问题
t = int(input())
for _ in range(t):
    n = int(input())
    a = list(map(int, input().split()))
    if n == 1 or n == 2:
        print(-1)
        continue
    a.sort()
    asum = sum(a)
    # aver = asum / n
    # index = bisect.bisect_left(a, aver/2)
    # if index > n // 2:
    #     print(0)
    #     continue
    # 接下来怎么办?
    # 增加数的问题,具有二分的性质
    # 考虑增加的数量为mid
    def check(mid):
        a[-1] += mid
        tmpsum = asum + mid
        aver = tmpsum / n
        index1 = bisect.bisect_left(a, aver/2)
        a[-1] -= mid
        return index1 > n // 2
    l,r = 0,10**12
    res = float('inf')
    while l<=r:
        mid = (l+r)//2
        if check(mid):
            res = min(res,mid)
            r = mid - 1
        else:
            l = mid + 1
    print(res)
相关推荐
PAK向日葵28 分钟前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者3 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
地平线开发者3 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9364 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑5 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
C++、Java和Python的菜鸟7 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀7 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散1127 小时前
01数据结构-Prim算法
数据结构·算法·图论
起个昵称吧7 小时前
线程相关编程、线程间通信、互斥锁
linux·算法
myzzb8 小时前
基于uiautomation的自动化流程RPA开源开发演示
运维·python·学习·算法·自动化·rpa