用java写一个算法:小美拿到了一个数组,她每次可以进行如下操作: 选择两个元素,一个加1,另一个减1。 小美希望若干次操作后,众数的出现次数尽可能多。你能帮她求出最小的操作次数吗?众数定义:在一
import java.util.Arrays;
public class MajorityElement {
public static void main(String[] args) {
int[] nums = {2, 3, -1, 2, 1, 3};
int minOperations = findMinOperations(nums);
System.out.println(minOperations);
}
public static int findMinOperations(int[] nums) {
int n = nums.length;
Arrays.sort(nums); // 将数组排序
int mid = nums[n / 2]; // 中位数即为众数
int minOperations = 0;
// 计算每个元素与中位数的差值的绝对值之和
for (int i = 0; i < n; i++) {
minOperations += Math.abs(nums[i] - mid);
}
return minOperations;
}
}
// 输出结果为:6
// 解释:将数组变为[-1, 1, 2, 2, 3, 3],众数为2和3,操作次数为6
public class MajorityElement {
public static void main(String[] args) {
int[] nums = {2, 3, -1, 2, 1, 3};
int minOperations = findMinOperations(nums);
System.out.println(minOperations);
}
public static int findMinOperations(int[] nums) {
int n = nums.length;
Arrays.sort(nums); // 将数组排序
int mid = nums[n / 2]; // 中位数即为众数
int minOperations = 0;
// 计算每个元素与中位数的差值的绝对值之和
for (int i = 0; i < n; i++) {
minOperations += Math.abs(nums[i] - mid);
}
return minOperations;
}
}
// 输出结果为:6
// 解释:将数组变为[-1, 1, 2, 2, 3, 3],众数为2和3,操作次数为6