第90百分位数的概念与计算
来源:互联网 发布:mac pro桌面图标大小 编辑:程序博客网 时间:2024/05/16 08:12
题目描述:
思路:
知乎上的讨论
今天做了道题,刚开始没读懂题,网上搜了一下关于第95百分位的解释,大家各有说法,各有自己的理解。但是看了很多人的评论也是,表示基本都看不懂。
从维基百科上可以找到这么一段话:
There is no standard definition of percentile, however all definitions yield similar results when the number of observations is very large and the probability distribution is continuous
可见对于百分位并没有十分标准的定义。所以仅在此简单总结一下第xth百分位的计算,以便日后查看,也希望大家能少走弯路,至于具体含义大家可以去维基百科查看。
既然网上没找到实现代码,就想到了Excel可能有相应的函数,果不其然。
其中:array为你的序列存储位置,比如A1:A12(在excel里的位置对应题目测试样例的array[0:11]),p为百分位值(以题目为例,p=0.9)
然后查了下它的实现原理:
首先将你的输入数组进行从小到大排序,然后计算:
其中n为数组元素的个数,将计算结果的整数部分用i表示,小数部分用j来表示。则最终的percentile值为:
因为题目给的数组是排好序的,所以我们计算(n-1)*p = (12-1)*0.9 = 9.9,则整数部分 i=9,小数部分j=0.9。查找数组得知,array[i] = array[9] = 7;array[i+1] = array[10] = 8。
因为,我们可以得到测试样例的结果为:
代码实现:
import java.util.*;public class Main { public static double getPercentile(int[] A, double p) { if (A == null) return 0; double res = 0; Arrays.sort(A);// 从小到大排序 double x = (A.length - 1) * p; int i = (int) x;// 取出整数部分 double j = x - i;// 还没找到最精确的取double数的小数部分的方法,有可能会有误差 res = (1 - j) * A[i] + j * A[i + 1]; return res; } public static void main(String[] args) { Scanner in = new Scanner(System.in); int n = in.nextInt(); double p = 0.9; double res; int[] A = new int[n]; for (int i = 0; i < n; i++) { A[i] = in.nextInt(); } res = getPercentile(A, p); System.out.println(res); }}
—–乐于分享,共同进步
—–Any comments greatly appreciated
- 第90百分位数的概念与计算
- 百分位数概念学习
- 关于百分位数的算法实现
- 百分位数(Percentile)
- 利用百分位数确定考核指标的具体数字
- 数据挖掘导论中3.2.2的百分位数计算方法
- 随机变量的分布与分位数概念
- JS 计算百分
- java 计算百分比值
- java 计算百分比值
- java 计算百分比值
- java 计算百分比值
- 百分位计算
- 处理器位数的概念
- 计算应用占用CPU的百分比及CPU的利用率
- 阶乘位数的计算
- 计算 1 的位数
- 计算整数的位数
- Java中的Math.random和random.nextInt区别
- Sumdiv POJ
- AJAX简介
- jQuery Ajax 等
- 关于js函数中this的一点理解
- 第90百分位数的概念与计算
- spring boot集成mybatis,启动报无法创建dataSource问题
- pai
- jQuery——元素特性、属性、数据操作
- 研究思路
- 使用redis服务器缓存数据库内容
- swoole不断的切换前端链接方法 防止攻击
- HDU 6002 贪心
- troubleshooting之控制shuffle reduce端缓冲大小以避免OOM