科学计算法帮助类MathUtils
import java.math.BigDecimal;
import java.math.MathContext;
import java.math.RoundingMode; /**
* 科学计算数字的帮助类
* @author yzl
*
*/
public class MathUtils {
/**
* 返回科学计算后的乘法结果
* @param val1
* @param val2
* @param mc 精度
* @param more 更多
* @return
*/
public static double multiply(double val1,double val2,int mc,double... more) {
if(val1==0 || val2==0) return 0;
BigDecimal bg1 = new BigDecimal(val1);
BigDecimal bg2 = new BigDecimal(val2);
BigDecimal result = new BigDecimal(0); if(more.length>0){
for(int i=0,len=more.length; i<len; i++){
if(i<len-1){
result = result.multiply(new BigDecimal(more[i]));
}else{
result = result.multiply(new BigDecimal(more[i]), new MathContext(mc,RoundingMode.HALF_UP));
}
}
}else{
result = bg1.multiply(bg2, new MathContext(mc,RoundingMode.HALF_UP));
} return result.doubleValue();
}
/**
* 返回科学计算后的除法结果
* @param fz 分子
* @param fm 分母
* @param mc 精度
* @param more 更多
* @return
*/
public static double divide(double fz,double fm,int mc,double... more) {
if(fz==0 || fm==0) return 0;
BigDecimal bg1 = new BigDecimal(fz);
BigDecimal bg2 = new BigDecimal(fm);
BigDecimal result = new BigDecimal(0); if(more.length>0){
for(int i=0,len=more.length; i<len; i++){
if(i<len-1){
result = result.divide(new BigDecimal(more[i]));
}else{
result = result.divide(new BigDecimal(more[i]), new MathContext(mc,RoundingMode.HALF_UP));
}
}
}else{
result = bg1.divide(bg2, new MathContext(mc,RoundingMode.HALF_UP));
} return result.doubleValue();
} /**
* 返回科学计算后的减法结果
* @param val1
* @param val2
* @param mc 精度
* @param more 更多
* @return
*/
public static double subtract(double val1,double val2,int mc,double... more) {
if(val2==0) return val1;
BigDecimal bg1 = new BigDecimal(val1);
BigDecimal bg2 = new BigDecimal(val2);
BigDecimal result = new BigDecimal(0); if(more.length>0){
for(int i=0,len=more.length; i<len; i++){
if(i<len-1){
result = result.subtract(new BigDecimal(more[i]));
}else{
result = result.subtract(new BigDecimal(more[i]), new MathContext(mc,RoundingMode.HALF_UP));
}
}
}else{
result = bg1.subtract(bg2, new MathContext(mc,RoundingMode.HALF_UP));
} return result.doubleValue();
} /**
* 返回科学计算后的加法结果
* @param val1
* @param val2
* @param mc 精度
* @param more 更多
* @return
*/
public static double add(double val1,double val2,int mc,double... more) {
BigDecimal bg1 = new BigDecimal(val1);
BigDecimal bg2 = new BigDecimal(val2);
BigDecimal result = new BigDecimal(0); if(more.length>0){
for(int i=0,len=more.length; i<len; i++){
if(i<len-1){
result = result.add(new BigDecimal(more[i]));
}else{
result = result.add(new BigDecimal(more[i]), new MathContext(mc,RoundingMode.HALF_UP));
}
}
}else{
result = bg1.add(bg2, new MathContext(mc,RoundingMode.HALF_UP));
} return result.doubleValue();
}
}
科学计算法帮助类MathUtils的更多相关文章
- C#中如何防止Excel做科学计算法转换
C#中如何防止Excel做科学计算法转换 string style = @"<style>.text{mso-number-format:\@;}</style>& ...
- Double类型的数值 在写入excel时 如何去掉 科学计算法的 后面数值+ E的 情况
Double start = 20190724100000.000; 写入excel时 是 201907E+13 但想要输出的是 20190724100000 这种格式 Java在java.math包 ...
- 导出到Excel并且取消默认的科学计算法
导出Excel的代码很多,其中这种最简单: protected void btnDCAll_Click(object sender, EventArgs e) { ...
- pandas中一列含有多种数据类型的转换:科学计算法转浮点数、字符映射
import pandas as pd import re def getNum(x): """ 科学计数法和字符转浮点数 """ if r ...
- php将科学计算法得出的结果转换成原始数据
由于php最大只支持显示 15位因的数据运算,大于15位的2数加减乘除的数据的结果,会直接用科学计数法显示, 但在现实生活中,科学计数法不利于普通人识别,所以,本函数将:科学计数法的出的结果转换成原始 ...
- php 将科学计算法得出的结果转换成原始数据 NumToStr
由于php最大只支持显示 15位因的数据运算,大于15位的2数加减乘除的数据的结果,会直接用科学计数法显示, 但在现实生活中,科学计数法不利于普通人识别,所以,本函数将:科学计数法的出的结果转换成原始 ...
- 解决 PHPExcel 长数字串显示为科学计数
解决 PHPExcel 长数字串显示为科学计数 在excel中如果在一个默认的格中输入或复制超长数字字符串,它会显示为科学计算法,例如身份证号码,解决方法是把表格设置文本格式或在输入前加一个单引号. ...
- oracle 将科学计数法数据转换为非科学计数法数据
oracle 自定义函数: CREATE OR REPLACE FUNCTION ConvertNumeric(rawData VARCHAR2) --用于返回转换科学计算法dhx RETURN VA ...
- 怎样批量把excel中已显示的科学计数法取消
作者:iamlaosong 把一文本文档拷贝到EXCEL中时,当中一列数字所有变成科学计数法,这些数事实上是条码号,不需进行运算,怎样能够取消科学计算法,将数字显示成原来的样子呢?一般方法例如以下: ...
随机推荐
- Android 官方文档:(一)动画和图像 —— 1.5 画布和画图
The Android framework APIs provides a set 2D drawing APIs that allow you to render your owncustom gr ...
- C#高性能大容量SOCKET并发(转)
C#高性能大容量SOCKET并发(零):代码结构说明 C#高性能大容量SOCKET并发(一):IOCP完成端口例子介绍 C#高性能大容量SOCKET并发(二):SocketAsyncEventArgs ...
- 详解Linux中CentOS6.8下解压安装mysql-5.7.14
原文:http://blog.csdn.net/yangle4695/article/details/52185859 mysql下载地址:http://dev.mysql.com/downloads ...
- iOS appStore中的应用 实现升级功能
.h文件中 <UIAlertViewDelegate> .m文件中 #import "SBJson.h" //解析sbjson 数据 - (void)vi ...
- POP数值动画
POP数值动画 效果 源码 https://github.com/YouXianMing/Animations // // PopNumberController.m // Animations // ...
- [翻译] AsyncImageView 异步下载图片
AsyncImageView https://github.com/nicklockwood/AsyncImageView AsyncImageView is a simple extension ...
- LODOP打印控件之LODOP.NewPageA()方法
通过lodop的强制分页方法,当我们一次性需要打印多张单页面的时候,可以通过该方法实现一次性打出,而不是重复调用打印方法,容易出问题 LODOP.NewPageA(); 说明:强制分页,注意是.New ...
- 计算均值mean的MapReduce程序Computing mean with MapReduce
In this post we'll see how to compute the mean of the max temperatures of every month for the city o ...
- Cocos2dx 3.0 过渡篇(二十七)C++11多线程std::thread的简单使用(下)
本篇接上篇继续讲:上篇传送门:http://blog.csdn.net/star530/article/details/24186783 简单的东西我都说的几乎相同了,想挖点深的差点把自己给填进去. ...
- HDU 3910 (13.10.31)
Description Maybe you know “San Guo Sha”, but I guess you didn’t hear the game: “Liang Guo Sha”! Let ...