大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
目录
1、名称解释
平均数:是指一组数据之和,除以这组数的个数,所得的结果就是平均数。
中位数:中位数是指把一组数据从小到大排列,如果这组数据的个数是奇数,那最中间那个就是中位数,如果这组数据的个数为偶数,那就把中间的两个数之和除以2,所得的结果就是中位数。
众数:众数是指一组数据中出现次数最多的那个数,众数可以是0个或多个。
2、实例代码
(1)求平均数
public static double mean(int[] arr) {
int sum = 0;
for (int i = 0; i < arr.length; i++) {
sum += arr[i];
}
return (double) sum / arr.length;
}
(2)求中位数
public static double median(int[] arr) {
// 先排序
Arrays.sort(arr);
// 如果是偶数,则为中间两个数的和除以2
if (arr.length % 2 == 0) {
return (double) ((arr[arr.length / 2 - 1] + arr[arr.length / 2])) / 2;
}
// 否则就是中间这个数
return arr[arr.length / 2];
}
(3)求众数
public static List<Integer> mode(int[] arr) {
Map<Integer, Integer> map = new HashMap<>();
Set<Map.Entry<Integer, Integer>> set = map.entrySet();
List<Integer> list = new ArrayList<>();
// 结果
List<Integer> res = new ArrayList<>();
// 统计元素出现的次数,存入Map集合
for (int item : arr) {
map.put(item, map.getOrDefault(item, 0) + 1);
}
// 将出现的次数存入List集合
map.forEach((k, v) -> {
list.add(v);
});
//集合排序
Collections.sort(list);
// 得到最大值
int max = list.get(list.size() - 1);
// 根据最大值获取众数
for (Map.Entry<Integer, Integer> entry : set) {
if (entry.getValue() == max) {
res.add(entry.getKey());
}
}
return res;
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/192555.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...