数马笔试算法10.15
小红拿到了一个长度为n的数组 a,每次操作小红可以选择数组中的任意一个数减去 x,小红一共能进行 k 次。小红想在 k 次操作之后,数组的最大值尽可能小。请你返回这个最大值。
n为1~10^5
a,k,x为1~10^9
示例输入:
5 3 5
1 4 3 11 2
输入为n,k,x 以及数组a的值
示例输出:
3
想知道这道题有没有比堆排更好的做法,我堆排一直tle。
import java.util.PriorityQueue;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
long k = scanner.nextLong();
long x = scanner.nextLong();
long[] a = new long[n];
PriorityQueue<Long> pq = new PriorityQueue<>((o1, o2) -> o2.compareTo(o1));
for(int i =0;i<n;i++){
a[i] = scanner.nextLong();
pq.add(a[i]);
}
while(k>0){
Long top = pq.poll();
Long nextTop = pq.peek();
Long dif = top-nextTop;
Long num = dif/x;
num = Math.min(k-1,num);
k-=(num+1);
top-=(num+1)*x;
pq.add(top);
}
System.out.println(pq.peek());
}
}
n为1~10^5
a,k,x为1~10^9
示例输入:
5 3 5
1 4 3 11 2
输入为n,k,x 以及数组a的值
示例输出:
3
想知道这道题有没有比堆排更好的做法,我堆排一直tle。
import java.util.PriorityQueue;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
long k = scanner.nextLong();
long x = scanner.nextLong();
long[] a = new long[n];
PriorityQueue<Long> pq = new PriorityQueue<>((o1, o2) -> o2.compareTo(o1));
for(int i =0;i<n;i++){
a[i] = scanner.nextLong();
pq.add(a[i]);
}
while(k>0){
Long top = pq.poll();
Long nextTop = pq.peek();
Long dif = top-nextTop;
Long num = dif/x;
num = Math.min(k-1,num);
k-=(num+1);
top-=(num+1)*x;
pq.add(top);
}
System.out.println(pq.peek());
}
}
全部评论
佬收到ai面了吗,我现在还没消息
二分答案
同优先队列,怒得1分
相关推荐
01-30 22:03
门头沟学院 Java
用微笑面对困难:我滴妈,【俩月】【实习】【主管】仨debuff吃满了,独立设计开发的项目写了绝大占比的运营板块,你独立开发,那维护、问题复盘、日志更新、bug、策划书全是自己整的? 点赞 评论 收藏
分享
03-22 21:15
景德镇陶瓷大学 C工程师
还是想躺平了:大厂发的海笔和逆天性格测评还不如不做,每次浪费两小时,笔试了一大堆一个面试都没有,双非是没全A都挂掉吗,我哪来的时间一边刷算法一边背八股 点赞 评论 收藏
分享
查看30道真题和解析