| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1929 人关注过本帖
标题:请问如何取整
只看楼主 加入收藏
初学vfp
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2020-2-22
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:5 
请问如何取整
各位,现编程练习,设要发放奖金,需要将个人所得金额取整,保留到元。
数据表终字段含义:yfjj → 应分奖金,qzjj → 取整奖金,全部总金额为776519。
我想到的方法:用四舍五入的办法,与总额有差,不好操作,可能是我的方法不得当。
另外可采用,将yfjj排序后,从某人的应分奖金数处开始,大于等于该数的,舍去尾数;小于该数的,收成整数(取名大舍小收),使取整后的总数恰好等于776519。但我不知道这种算法如何写程序?还有其他更好的方法吗?谢谢!
tj.zip (1.19 KB)

搜索更多相关主题的帖子: 等于 金额 方法 取整 大于 
2020-02-22 20:03
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:7 
用总额做控制的,要取一个人来调整。
等式:第n人的金额 = 总额 - (n-1)个人的四舍五入之和
2020-02-22 21:14
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:6 
yfjj总和为:776519.12元
从财务管理角度上讲,不论楼主采用那种方法都是不可取的,应该采用最大值取整,或者最小值取整。凑数的方法是不可取的,不是解决问题之道。

坚守VFP最后的阵地
2020-02-23 09:22
pjtyzyq
Rank: 4
等 级:业余侠客
威 望:6
帖 子:232
专家分:240
注 册:2016-2-14
收藏
得分:7 
将所有金额小数部分数值求和,求和的值理论上应该是整数(XX元),然后对每个人金额的小数值部分由大到小排序,将求和的整数按每人加一元的方式进行分配,直到求和后的数值为零。

将所有金额整数部分数值求和,再776519-求和的值差值,然后对每个人金额的小数值部分由大到小排序,将差值按每人加一元的方式进行分配,直到差值的数值为零。

[此贴子已经被作者于2020-2-23 14:35编辑过]

2020-02-23 14:18
初学vfp
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2020-2-22
收藏
得分:0 
谢谢楼上各位的解答,我理一理思路,试一试哈。
2020-02-23 14:58
xs591222
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:28
帖 子:682
专家分:1299
注 册:2009-3-1
收藏
得分:0 
如果四舍五入后,总额超1,则最靠近0.5的那个改为舍
如果四舍五入后,总额缺1,则最被舍的当中最接近0.5的那个改为入。
这个是可以用代码来实现的
2020-03-04 19:06
快速回复:请问如何取整
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021267 second(s), 12 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved