news 2026/2/17 15:06:16

小美的数组操作【牛客tracker 每日一题】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
小美的数组操作【牛客tracker 每日一题】

小美的数组操作

时间限制:1秒 空间限制:256M

网页链接

牛客tracker

牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】,换取相应奖品!助力每日有题做,丰盈牛币日益多!

题目描述

小美拿到了一个数组,她每次可以进行如下操作:
选择两个元素,一个加1 11,另一个减1 11

小美希望若干次操作后,众数的出现次数尽可能多。你能帮她求出最小的操作次数吗?

众数定义:在一组数据中,出现次数最多的数据,是一组数据中的原数据,而不是相应的次数。 一组数据中的众数不止一个,如数据2 、 3 、 − 1 、 2 、 1 、 3 2、3、-1、2、1、3231213中,2 、 3 2、323都出现了两次,它们都是这组数据中的众数。

输入描述:

第一行为一个正整数n nn,代表数组的大小。
第二行输入n nn个正整数a i a_iai​,代表小美拿到的数组。
1 ≤ n ≤ 10 5 1≤n≤10^51n105
1 ≤ a i ≤ 10 9 1≤a_i≤10^91ai109

输出描述:

一个整数,代表最小的操作次数。

示例1

输入:

3 1 4 4

输出:

2

说明:

第一次操作:第一个数加1 11,第二个数减1 11
第二次操作:第一个数加1 11,第三个数减1 11
数组变成[ 3 , 3 , 3 ] [3,3,3][3,3,3],众数出现了3 33次。

示例2

输入:

3 1 5 5

输出:

0

说明:

众数出现了2 22次,由于无法再用操作使得众数出现的次数变得更多,所以无需操作。

解题思路

本题依托数组总和守恒的核心特性(每次操作一增一减不改变总和),明确众数能达到的最大次数为数组长度n nn(总和可均分时)或n − 1 n-1n1(总和不可均分时),先判断数组总和是否能被n nn整除,若可以则直接计算所有元素转为该平均值的总操作次数作为答案;若不可均分则无法让全部元素相同,进一步剔除数组中的最大值、最小值分别计算剩余n − 1 n-1n1个元素总和的均分候选值,结合余数核算两种目标取值的操作成本,最终取所有候选方案中的最小操作次数,高效适配n ≤ 10 5 n≤10⁵n105的数据规模,精准得到满足众数次数最大化的最小操作代价。

代码内容

#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;typedefunsignedlonglongull;typedefpair<ll,ll>pii;constll p=1e9+7;constll N=1e6+10;intmain(){ll n;cin>>n;ll v[n];ll sum=0;ll m=0,M=0;for(ll i=0;i<n;i++){cin>>v[i];sum+=v[i];if(v[i]>v[M])M=i;if(v[i]<v[m])m=i;}function<ll(ll,ll)>cal=[&](ll p,ll idx){ll res=0;for(ll i=0;i<n;i++){if(i==idx)continue;if(v[i]>p)res+=v[i]-p;}returnres;};ll ans=0;if(sum%n==0)ans=cal(sum/n,-1);else{ll k=(sum-v[M])%(n-1);ans=cal((sum-v[M])/(n-1),M);ans=min(ans,cal((sum-v[M])/(n-1)+1,M)+n-1-k);k=(sum-v[m])%(n-1);ans=min(ans,cal((sum-v[m])/(n-1),m));ans=min(ans,cal((sum-v[m])/(n-1)+1,m)+n-1-k);}cout<<ans<<endl;return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/17 11:02:20

从零到一:Proteus与51单片机打造智能交通灯的实战指南

从零到一&#xff1a;Proteus与51单片机打造智能交通灯的实战指南 1. 项目概述与核心价值 智能交通灯系统作为嵌入式开发的经典练手项目&#xff0c;融合了硬件设计、软件编程和系统调试三大核心技能。对于初学者而言&#xff0c;这个项目就像一把钥匙&#xff0c;能够打开嵌入…

作者头像 李华
网站建设 2026/2/10 19:59:20

小白必看!EasyAnimateV5图生视频保姆级入门指南

小白必看&#xff01;EasyAnimateV5图生视频保姆级入门指南 你是不是也试过对着一张静态图发呆&#xff0c;心想&#xff1a;“要是它能动起来该多好&#xff1f;” 或者刚拍了一张氛围感十足的照片&#xff0c;却卡在“怎么让它自然地动起来”这一步&#xff1f; 别折腾了——…

作者头像 李华
网站建设 2026/2/17 9:52:13

5个效率爆点!Cool Request让IntelliJ IDEA接口调试快到飞起

5个效率爆点&#xff01;Cool Request让IntelliJ IDEA接口调试快到飞起 【免费下载链接】cool-request IDEA中快速调试接口、定时器插件 项目地址: https://gitcode.com/gh_mirrors/co/cool-request 作为Spring Boot开发者&#xff0c;你是否也曾经历过这些抓狂瞬间&…

作者头像 李华
网站建设 2026/2/11 16:37:27

超越流水灯:AT89C51的GPIO创意应用实验室——从基础电路到智能交互原型

超越流水灯&#xff1a;AT89C51的GPIO创意应用实验室 当大多数初学者还在用AT89C51实现流水灯效果时&#xff0c;真正的硬件玩家已经开始探索GPIO更富创意的应用场景。这片8位单片机的战场远不止于让LED从左闪到右——通过巧妙设计&#xff0c;它能成为智能交互原型的核心控制…

作者头像 李华