百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

7种常见“小数处理”模型

csdh11 2025-03-04 11:40 2 浏览

在交易范畴和支付范畴里面,我们常常会发现小数除不尽的情况。本文总结了7种常见“小数处理”模型,供大家在实际场景中选择合适的模型。

在交易范畴和支付范畴经常出现小数除不尽,或者乘数结果小数位数太多的情况,需要对小数进行处理因为,数据库存储小数,往往会设定位数或者最小单位,例如保留两位小数,或者金额的最小单位为分,数值只能为整数。

常见的业务有以下这些:

  • 交易范畴的优惠分摊金额的小数处理
  • 支付范畴的多次分账每次分账金额的小数处理
  • 收款手续费处理
  • 多次退款的手续费处理
  • 利息的处理

一、除不尽的场景

分摊时,如一笔订单优惠10元,分摊到3个商品上,那么每个商品分摊多少,很明显10?3=3.333…是除不尽的,这时候最终每个商品分摊了多少优惠?分账时,如一笔收款100块,现在要平均分账7笔,每笔应该分多少钱,这里100?7=14.2857143…,那么如何执行分账?

二、相乘位数增加的场景

计算手续费时,例如手续费率0.38%,一笔收款568元,此时应收手续费568*0.38%=2.158假如需要保留两位小数,那么最终手续费收多少呢?这里的规则需要跟商户预先约定方法不重要,重要的是共识,没有合不合理,只有愿不愿意。

大原则肯定是“公平”,何为公平就是“不多付一分钱,不少收一分钱,刚刚好”,而出现小数要处理也是迫不得已,那么也要尽可能保证公平,如果实在是做不到绝对公平,那么就做到各方共识,都能接受。

下面总结了7种常见的小数处理方法,以及适用的场景,全部以保留2位小数为前提。

1. 去尾法

保留位数后的值直接舍去,这个方法会让数偏小可以用在“不能高于”的限制场景,比如多次分账,不能超过总分账金额,那么前面的分账都可以直接去尾,最后进行调整示例:

568*0.38%=2.159,去尾以后为2.15像银行给客户的利息可以考虑去尾法,这样整体来说,可以降低银行的资金成本另外我们日常买东西也经常用去尾法,比如买菜,一共2.53,你可能会说“老板,零头别要了”,直接2.5就可以了。

2. 进一法

只要保留位数以后有数值,则直接进一,数会偏大可以在“不低于的“限制场景使用,比如你去给领导买可乐,一共8个领导,每人一瓶;假如一箱共6瓶可乐,那么8?6=1.3333…,只能买2箱(不零卖)示例:568*0.38%=2.151,有数则进1,处理后结果为2.16

3. 四舍五入

这是最常见的处理方法,整体数值会偏大,小于5时舍去,大于等于5时进一像微信的交易收款手续费采用的就是“四舍五入法”示例:568*0.38%=2.158,8大于5直接进1,为2.16

4. 四舍六入五成双

该方法比“四舍五入”更精确,当数据量大时结果更接近真实数值因为1、2、3、4、5、6、7、8、9中,5正好在中间位置,如果四舍五入,很明显进一的场景要比舍去的场景多“1”那么为了更公平就以5为分界线,小于5舍去,大于5进1,而当等于5时分情况处理如果5后还有数则进1,例如2.12500009,因为5后还有数,那么就进1,结果为2.13如果5后没有数了,要看5前面的数是奇数还是偶数,奇数时舍5进1,偶数时舍5不进(0为偶数),例如:2.175,5前面的“7”是奇数,则舍5进1,结果为2.182.165,5前面的“6”是偶数,则舍5不进,结果为2.16

5. 余数分配,补差法

当除不尽时,对余数设定分配策略,先处理除尽的部分,最后补全差额,这样的方法会让个别有误差,但整体没有误差例如开头的分摊例子:

一笔订单优惠10元,分摊到3个商品上,那么每个商品分摊多少,很明显10?3除不尽,整数结果是3,余数是1,那么2个商品分摊3,另一个分摊4如果保留2位小数,则10?3=3.333333…,其中2个商品分摊3.33,最后一个商品分摊10-3.33-3.33=3.34该方法可以用于优惠分摊和分账,包括退款手续费的处理,微信的退款手续费规则中有该方法余数分配方法可以与其他方法联合使用,以确保最终的公平性例如微信多次退款时的手续费处理,前面按照“向下取整”的策略,而最后一次退款退回全部手续费,实际上就是对余数进行补齐的策略,虽然前面手续费少退了,但是最后全给你补上了

6. 向上取整

有数值则进1,这样会让数值偏大,但在最后一次进行调整,保证整体无误差,如微信支付在规则调整前部分退款的手续费是“向上取整”,这样就意味着多次退款时,前面返给商家的手续费偏高示例:2.12100009,向上取整则结果为2.13,看起来和进一法效果类似

7. 向下取整

与向上取整向反,直接舍去,跟去尾法相似目前微信支付多次退款的手续费退回处理策略是“向下取整”微信支付采用了多种小数处理策略,交易手续费采用“四舍五入”,多次退款时采用“向下取整+余数补齐”例如开头的交易示例:手续费率0.38%,一笔收款568元,此时应收手续费568*0.38%=2.158,“四舍五入”以后为2.16如果全额退款直接退2.16即可如果是部分时,退款手续费计算规则是:

退款手续费=退款金额/总金额*交易手续费

  • 假如第一次退款268元,则268/568*2.16=1.019=1.01(向下取整)
  • 第二次退款169元,则169/568*2.16=0.642=0.64(向下取整)
  • 第三次退131元,即退剩下的全部,则应退手续费2.16-1.01-0.64=0.51(余数分配,调整差额)

最后,实际工作中可以根据实际业务情况灵活选择和组合,或者设计出更优的模型出来,例如“平常向下取整,年终一次性补齐整体差额”等,以确保尽可能的公平和大家都能接受的模型执行。

专栏作家

陈天宇宙,微信公众号:陈天宇宙,人人都是产品经理专栏作家。多平台支付领域专栏作者,十年资深产品;专注为10万支付产品经理和支付机构以及企业提供深度支付内容和服务!

本文原创发布于人人都是产品经理,未经许可,禁止转载。

题图来自 Unsplash,基于 CC0 协议。

该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。

相关推荐

Excel表格技巧—如何保留小数点后两位

在我们日常使用Ofiiceexcel中,经常会用到小数点保留,对此人们习惯性会使用单元格格式设置,不过这种办法并不是真正的四舍五入,而只是改变了excel的显示。我们下面要介绍的这个方式是利用函数做...

小数的意义和性质(十四)

27、在一个两位小数的末尾添上一个0,与原来小数相比,多了1107个计数单位,这个小数原来是多少?举个例子:0.35的末尾添上一个0,就变成了0.350,0.35里有35个0.01,0.350里有35...

必看!文职人员等级标志及有关问题20条!

来源:中国民兵微信公众号大道至简!为了让大家更多了解文职政策、报考文职的粉丝们最快、最直接掌握政策。首先是上独家解读和壁纸。然后,结合独家资料,梳理出20条有关文职的干货,快快收藏吧!1.文职人员的身...

小学数学单元知识体系概述-五年级《小数除法》

一、网络图二、知识点梳理及举例说明1.除数是整数。1)除到被除数的末尾没有余数,能除尽。举例:22.4÷4。...

“分数,小数,百分数 的互化”我这样教学,学生很快就学会了。

这部分知识千万不能忽视,用途可大了。我们在进行分数,小数,百分数四则混合运算时,不会三者之间的转化,很难把题计算准确。那么三者之间怎样转化呢?其实就这么几步:一,分数化小数,用分数的分子除以分数的分...

求小数近似数的最大值和最小值的技巧

例:一个两位小数,四舍五入后的近似数是5.0,这个三位小数最大可能是(),最小可能是()。分析:保留一位小数要看百分位上的数和5比较,若小于5的数舍去;若≥5的数,向前一位进一。四舍是最大,五入是...

实验室检测双乙酰的操作步骤

双乙酰学名是2,3丁二酮,是啤酒发酵过程中酵母自身代谢产生的一种副产物,当双乙酰的含量在浅色啤酒中超过0.15mg/L时,就会使啤酒产生一种令人不愉快的馊饭味,严重影响啤酒的质量和口感,在啤酒中双乙酰...

快来看!玉溪2020年中考分数段出炉

8月7日市教育体育局公布玉溪市2020年初中学业水平考试分数段据介绍,今年,玉溪市普通高中学校招生文化成绩满分为600分(不含照顾加分),由初中学业水平考试的13个学科成绩折算而得,总分累加保留两位小...

截取近似值的方法有几种?在生活中怎样应用这些方法?(21)

根据生活中的实际情况,截取近似值的方法有以下三种:(1)、四舍五入法:...

Excel数值取整及进位

取整数函数907.5;1034.2;1500要改变为908;1035;1500公式为:=CEILING(A1,1)907;1034;1500要改变为910;1040;1500公式为:...

C语言sprintf函数详解:“字符串魔法师”

♂?一句话理解sprintf「将数据按‘魔法咒语’(格式字符串)格式化,并将结果‘封印’到一个字符数组中!」...

sql server 数字四舍五入 保留两位小数

1.使用Round()函数,如Round(@num,2),其中参数2表示保留两位有效数字。缺点:Round()只是负责四舍五入到两位小数,但是不负责去掉后面的0。...

excel表格保留两位小数怎么保留?教您4种设置方法

保留两位小数怎么保留?有4种解决方法,我们来具体演示一下。·方法一:选择需要设置的单元格,然后点击开始菜单,数字功能区,点击增加小数位数或者是减少小数位数,调到保留两位就可以了。·方法二:选择需要设置...

如何对数字进行四舍五入,进一法,去尾法,精度法等不同方式取舍

指定位数取有效位针对数值我们有不同的处理方式,比如保留一位小数位,保留两位小数位,保留整数位等,一般我们都是采用四舍五入...

保留n位小数的函数公式

在日常办公中,Excel和WPS是我们处理数据的得力助手。今天,我们将介绍几个常用的函数,帮助你在数据处理中事半功倍。...