题解 | #游游的元素修改#

游游的元素修改

http://www.nowcoder.com/questionTerminal/2e3557c96138444db7eca60e8afaaac7

贪心!
由于操作时一个数+1,另一个数字-1,所以最终的数组的总和是保持不变的,因此可以知道如果数组的总和sum 在 n * l 和 n * r 之间的话,是一定有解的
然后计算变大变小各自需要的操作次数,取最大值就行(多的那几步就需要利用 [l,r]区间内的某些数进行辅助操作)
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int t = in.nextInt();
        while (t-- != 0) {
            int n = in.nextInt(), l = in.nextInt(), r = in.nextInt();
            long sum = 0;
            int[] nums = new int[n];
            long smallCnt = 0, bigCnt = 0;
            for(int i = 0; i < n; i++) {
                nums[i] = in.nextInt();
                sum += nums[i];
                if(nums[i] < l) {
                    smallCnt += l - nums[i];
                }
                if(nums[i] > r) {
                    bigCnt += nums[i] - r;
                }
            }

            if(sum > 1l * n * r || sum < 1l * n * l) {
                System.out.println(-1);
                continue;
            }

            System.out.println(Math.max(smallCnt, bigCnt));
        }
    }
}


全部评论

相关推荐

叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务