12年的时候在做一个电子商城项目,一个类似淘宝卖东西的网站。
B2C 商家对用户模式。
用户在平台选好商品,下订单,再进行支付。这个支付用的是第三方平台 umpay 。
订单是:60.00
支付金额:59.99
public static void main(String args[]){
System.out.println(6.00 - 5.10);
}
你可能会很天真地期望该程序能够打印出 0.90,但是它如何才能知你想要打
印小数点后两位小数呢?
如果你对在Double.toString 文档中所设定的将 double类型的值转换为字符串
的规则有所了解,你就会知该程序打印出来的小数,是足以将double类型的
值与最靠近它的临近值区分出来的最短的小数,它在小数点之前和之后都至少有
一位。因此,看起来,该程序应该打印 0.9 是合理的。
解决该问题的一种方式是使用某种整数类型,例如 int 或 long,并且以分为单
位来执行计算。如果你采纳了此路线,请确保该整数类型大到足够表示在程序中
你将要用到的所有值。对这里举例的谜题来说,int 就足够了。下面是我们用 int
类型来以分为单位表示货币值后重写的println 语句。这个版本将打印出正确答
案
解决该问题的另一种方式是使用执行精确小数运算的BigDecimal。它还可以通
过 JDBC 与SQL DECIMAL 类型进行互操作。这里要告诫你一点: 一定要用
BigDecimal(String)构造器,而千万不要用BigDecimal(double)。后一个构造
器将用它的参数的 “精确”值来创建一个实例:new BigDecimal(.1)将返回一个
表示 0.100000000000000055511151231257827021181583404541015625 的
BigDecimal。通过正确使用BigDecimal,程序就可以打印出我们所期望的结果
0.90:
import java.math.BigDecimal;
public class Test{
public static void main(String args[]){
System.out.println(new BigDecimal("2.00").
subtract(new BigDecimal("1.10")));
}
}
总之, 在需要精确答案的地方,要避免使用float 和 double;对于货币计算,
要使用 int、long 或 BigDecimal。对于语言设计者来说,应该考虑对小数运算
提供语言支持。一种方式是提供对操作符重载的有限支持,以使得运算符可以被
塑造为能够对数值引用类型起作用,例如BigDecimal。另一种方式是提供原始
的小数类型,就像 COBOL 与PL/I 所作的一样。
相关推荐
简单的找零系统,没有后台的数据库。可以实现5毛,1元硬币的显示。
货币找零计算找给顾客固定钱数的最小货币量java 原代码
这是一个利用动态规划的最少硬币找零算法,时间效率符合要求
假定商店里各面值的硬币有足够多,顾客也可用多种方式支付。在1次购物中希望使用最少硬币个数。例如,1次购物需要付款0.55元,没有5角的硬币,只好用2*20+10+5共4枚硬币来付款。如果付出1元,找回4角5分,同样需要4...
找零功能输入金额(元)和票面(元)找零 喜欢的话可以下载
算法设计 硬币找零 程序 算法设计 硬币找零 程序 算法设计 硬币找零 程序 算法设计 硬币找零 程序
一个简单的动态规划算法实例,实现硬币找零的最小硬币数以及每种面额硬币的数量。
找零的方法很多,我在此列举的只是其中之一,比较经典的,简单易懂,适合初学者。
Deli得力12位找零语音计算器说明书.pdf
一个自动售货机找零系统 使用visual studio 2008 开发平台,运用了stl技术。
电子政务-基于二维码的停车场电子支付或找零系统及方法.zip
一场激烈足球赛即将开始,售票员紧张地卖票着……。 每张球票50元,现在有2n(1)个球迷排队购票,其中n个...假设开始售票时售票处没有零钱可以找零。 问这2n个人有多少种排队方式,不至使售票处出现找不出零的局面?
详细的背包问题和超市找零问题的解说, 代码详细,注释清除,方便使用
C++贪心算法超市找零问题代码实现,分享给大家参考一下。
11085 买票找零 时间限制:1000MS 内存限制:65535K 提交次数:0 通过次数:0 题型: 编程题 语言: 无限制 Description 一场激烈足球赛即将开始,售票员紧张地卖票着……。 每张球票50元,现在有2n(1)个球迷排队...
自动售货机,支持5种商品的预设数量,价格,可以选择购买商品及其数量,可以输入0.5,1.5三种金额。支持找零。
假设开始售票时售票处没有零钱可以找零。 问这2n个人有多少种排队方式,不至使售票处出现找不出零的局面? 例如当n=3时,共6人,3人持50元,3人持100元。可以找零的排队方式有如下5种: 50 50 50 100 100 100 50 50...
贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即...请注意,贪心算法并不总是能得到全局最优解,但在钱币找零问题中,如果钱币面额设计合理(例如常见的1、5、10、25等),贪心算法可以保证得到最优解。
主 要 用 于 M K 2 硬 币 器 开 发,及 测 试 程 序!
贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即...请注意,贪心算法并不总是能得到全局最优解,但在钱币找零问题中,如果钱币面额设计合理(例如常见的1、5、10、25等),贪心算法可以保证得到最优解。