两个double相减_js中两个小数相减,出现的多位小数

好久以前写过一个小库,自以为还挺好用的。核心也就是先转整数,运算完成再转小数,当然转的方法不是像@mcfog兄反对的那样直接乘以100,要不还是会出现问题的,而是先转字符串去掉小数点。

用法如下:

//使用数字的literal表示,创建一个Decimal对象

var d1 = new Decimal(3.68);

//调用该对象的四则运算方法,得到一个新的Decimal对象

var res=d1.add(2.25);

//调用该对象的valueOf方法,得到数值

alert( res.valueOf() ); //显示 5.93

//或者调用该对象的toString方法,得到数值的字符串表示

alert( res.toString() ); //显示 5.93

//可用的运算方法对应四则运算的+、-、×、÷

var d1 = new Decimal(3.68);

var res=d1.add(2.25);

assertEquals("3.68+2.25", "5.93", res.toString());

var d1 = new Decimal(3.68);

var res=d1.minus(2.25);

assertEquals("3.68-2.25", "1.43", res.toString());

var d1 = new Decimal(2.22);

var res=d1.multiply(3.33);

assertEquals("2.22*3.33", 7.3926, res.valueOf());

var d1 = new Decimal(6.66);

var res=d1.divide(2.22);

assertEquals("6.66/2.22", 3, res.valueOf());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的可以小数运算,带优先级的四则运算计算器的C代码: ``` #include <stdio.h> #include <stdlib.h> #include <ctype.h> #define MAX_EXPR_LEN 100 double factor(void); double term(void); double expr(void); char expr_str[MAX_EXPR_LEN + 1]; int index = 0; int main(void) { printf("请输入一个四则运算表达式(带小数):\n"); fgets(expr_str, MAX_EXPR_LEN, stdin); printf("%s = %g\n", expr_str, expr()); return 0; } double factor(void) { double result; char curr_char = expr_str[index]; if (isdigit(curr_char) || curr_char == '.') { result = atof(&expr_str[index]); while (isdigit(expr_str[index]) || expr_str[index] == '.') { index++; } } else if (curr_char == '(') { index++; result = expr(); if (expr_str[index] == ')') { index++; } else { fprintf(stderr, "右括号缺失\n"); exit(EXIT_FAILURE); } } else if (curr_char == '-') { index++; result = -factor(); } else { fprintf(stderr, "无效字符: %c\n", curr_char); exit(EXIT_FAILURE); } return result; } double term(void) { double left = factor(); while (expr_str[index] == '*' || expr_str[index] == '/') { char op = expr_str[index]; index++; double right = factor(); if (op == '*') { left *= right; } else { left /= right; } } return left; } double expr(void) { double left = term(); while (expr_str[index] == '+' || expr_str[index] == '-') { char op = expr_str[index]; index++; double right = term(); if (op == '+') { left += right; } else { left -= right; } } return left; } ``` 该程序首先使用`fgets()`函数从标准输入读入一个表达式字符串,然后使用三个函数`factor()`、`term()`和`expr()`分别计算该表达式的因子、项和表达式的值。 `factor()`函数用于计算表达式的因子,返回一个`double`类型的值。如果当前字符是数字或小数点,那么就使用`atof()`函数将其转换为`double`类型的数值,并将`index`指向下一个非数字字符。如果当前字符是左括号,则递归调用`expr()`函数计算括号内的表达式,并确保右括号存在。如果当前字符是负号,则将其后的因子计算出来并取反。 `term()`函数用于计算表达式的项,返回一个`double`类型的值。首先计算左边的因子,然后使用一个循环计算乘法和除法。如果当前字符是乘号,则计算右边的因子并与左边的因子相乘,否则计算右边的因子并与左边的因子相除。循环直到没有乘法或除法运算符为止。 `expr()`函数用于计算表达式的值,返回一个`double`类型的值。首先计算左边的项,然后使用一个循环计算加法和减法。如果当前字符是加号,则计算右边的项并与左边的项相加,否则计算右边的项并与左边的项相减。循环直到没有加法或减法运算符为止。 该程序使用了递归下降解析器,可以处理带优先级的四则运算表达式,包括小数计算。但该程序对输入表达式的有效性检查非常有限,如果输入的表达式格式不正确,可能会导致程序出错。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值