开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2773|回复: 2
收起左侧

[易源码分享] 求一段数据内百分位 源码

[复制链接]
结帖率:97% (99/102)
发表于 2023-1-23 13:24:42 | 显示全部楼层 |阅读模式   重庆市重庆市
分享源码
界面截图:
是否带模块: 纯源码
备注说明: -
  
子程序名返回值类型公开备 注
统计_求数据中具体百分位数值文本型 返回百分位对应数值
参数名类 型参考可空数组备 注
参_数据文本型原始数据
参_百分位文本型输入0.25 即25%百分位数值
变量名类 型静态数组备 注
局_数据百分位数组文本型接收后计算后的数据百分比数组
局_数量整数型 
局_数据百分位文本型 
局_数据百分位临时数值文本型 
n整数型 
R双精度小数型要求的百分位数据 对应的从小到大排序后 1,2,3,4 的序号
返回文本型 
' 数据  从小到大排序
' 总数据样本数量M   数据位置N   数据百分位P=  (N-1)/(M-1)
' 测试  my_list=[1,2,2,3,4,56,123,21,34]
' 从小到大排序后 数组百分位
' {“0.000”,“0.125”,“0.125”,“0.375”,“0.500”,“0.625”,“0.750”,“0.875”,“1.000”}
' my_list = { “2”, “3”, “5”, “7”, “9”, “1”, “2”, “6”, “20” }
' 从小到大排序后 数组百分位
' {“0.000”,“0.125”,“0.125”,“0.375”,“0.500”,“0.625”,“0.750”,“0.875”,“1.000”}
' 数值:2,3,5,7,9,12,16,20
' 序号:1,2,3,4,5, 6, 7, 8
' 假设第R个小朋友刚好取得x个苹果:
' R=0.25*(8+1)
' R=2.25
' 所以取值为第25百分位数的小朋友序号为2.25
' 因为R=2.25,介于序号2和序号3之间,所以对应的百分位数x在3和5之间(3是序号为2的数值,5是序号为3的数值),假设数值之间是连续线性的关系:
' x=3+(R-2)*(5-3)=3+(2.25-2)*(5-3)=3.5
' 因此小朋友圣诞节收到苹果的第25百分位数就是3.5
' 公式:R=(P/100)*(N+1)
' R: Percentile Rank 代表序号,用于表示取百分位数时的数据序号
' P: Percentile 代表第P百分位数,经典值有25,50,75等
' N: Number of Data 代表数据集里数字的个数
局_数量 = 取数组成员数 (参_数据)
' 调试输出 (参_数据)
如果 (局_数量 > 0)
排序_希尔排序_文本数组 (参_数据)  ' 从小到大排序
' 调试输出 (参_数据)
' (8-1)*0.25=1.75,然后+1=2.75即位置。x=3+(R-2)*(5-3)=4.5
R = 到数值 (参_百分位) (局_数量 - 1)
' 2023年1月17日 06:12:03 下面这个知乎算法 不包含最小和最大两端 不适合统计学
' R = 到数值 (参_百分位) × (局_数量 + 1)
如果 (R = 到整数 (R))
' 整数 直接取对应序号
返回 = 参_数据 [R]
' 不是整数 取相邻2个数的线性关系运算出具体数值
R = R + 1
返回 = 到文本 (到数值 (参_数据 [取整 (R)]) (R - 取整 (R)) (到数值 (参_数据 [取整 (R) + 1])到数值 (参_数据 [取整 (R)])))  ' 注意评论 有好几种算法 [url]https://zhuanlan.zhihu.com/p/403526560[/url]

返回 (返回)  ' 计算完毕 有内容 返回

返回 (“”)  ' 异常 空数组 返回假


  
子程序名返回值类型公开备 注
_按钮7_被单击  
变量名类 型静态数组备 注
数据双精度小数型 
my_list文本型0
百分比排序数组文本型0
局_结果文本型 
' my_list = { “1”, “2”, “2”, “3”, “4”, “56”, “123”, “21”, “34” }
' my_list = { “2”, “3”, “5”, “7”, “9”, “12”, “16”, “20” }
my_list = { “2”, “3”, “5”, “7”, “9”, “12”, “16”, “20”, “20”, “20”, “20”, “20”, “20”, “20” }
局_结果 = 统计_求数据中具体百分位数值 (my_list, “0.25”)
调试输出 (局_结果)


i支持库列表   支持库注释   
spec特殊功能支持库


备份  效果等同于python的stats.scoreatpercentile

源码里面的希尔排序是论坛的 需要自己改自定义类型我就没上传了 随便什么排序的模块都行 按照从小到大排序 希尔排序是快点 不然数据太多2个循环挨个比较可能耗时太久

测试数组 { “2”, “3”, “5”, “7”, “9”, “12”, “16”, “20”, “20”, “20”, “20”, “20”, “20”, “20” }  的25%位置  是7.5  数据验算excel,易语言,python一致

结帖率:73% (8/11)

签到天数: 20 天

发表于 2023-1-23 22:45:57 | 显示全部楼层   河南省焦作市

okok 感谢分享
回复 支持 反对

使用道具 举报

结帖率:80% (57/71)

签到天数: 18 天

发表于 2023-1-23 13:58:40 | 显示全部楼层   广东省深圳市
[易源码分享]

[分享源码]


求一段数据内百分位 源码

你看看你发的什么?
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表