数学运算公用类ArithUtils

import java.math.BigDecimal;
import java.util.Random;

public class ArithUtils {
/**
* 默认除法运算精度
*/
private static final int DEF_DIV_SCALE = 10;
/**
* 提供精确的加法运算。
* @param v1 被加数
* @param v2 加数
* @return 两个参数的和
*/
public static double add(double v1,double v2){
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
/**
* 提供精确的减法运算。
* @param v1 被减数
* @param v2 减数
* @return 两个参数的差
*/
public static double sub(double v1,double v2){
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
/**
* 提供精确的乘法运算。
* @param v1 被乘数
* @param v2 乘数
* @return 两个参数的积
*/
public static double mul(double v1,double v2){
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
/**
* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
* 小数点以后10位,以后的数字四舍五入。
* @param v1 被除数
* @param v2 除数
* @return 两个参数的商
*/
public static double div(double v1,double v2){
return div(v1,v2,DEF_DIV_SCALE);
}
/**
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
* 定精度,以后的数字四舍五入。
* @param v1 被除数
* @param v2 除数
* @param scale 表示表示需要精确到小数点以后几位。
* @return 两个参数的商
*/
public static double div(double v1,double v2,int scale){
if(scale<0){
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 提供精确的小数位四舍五入处理。
* @param v 需要四舍五入的数字
* @param scale 小数点后保留几位
* @return 四舍五入后的结果
*/
public static double round(double v,int scale){
if(scale<0){
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}

/**
* 非整除则进位
* @param i1
* @param i2
* @return
*/
public int round(int i1,int i2){
int modi = 0;
modi = i1 % i2;
int i = i1/i2;
if(modi==0){
return i;
}else{
return i+1;
}
}

/**
* 使用时一定要注意其大小,不可超出范围
* @param i1
* @param i2
* @return
*/
public int pow(int i1,int i2){
double d1 = (double)i1;
double d2 = (double)i2;
return (int)java.lang.Math.pow(d1, d2);
}

/**
* 对给定数目的自0开始步长为1的数字序列进行乱序
* @param maxnum
* @return
*/
public static int[] getSequence(int maxnum) {
int[] sequence = new int[maxnum];
for(int i = 0; i < maxnum; i++){
sequence[i] = i;
}
Random random = new Random();
for(int i = 0; i < maxnum; i++){
int p = random.nextInt(maxnum);
int tmp = sequence[i];
sequence[i] = sequence[p];
sequence[p] = tmp;
}
random = null;
return sequence;
}

public static void main(String[] agrs){
ArithUtils arith = new ArithUtils();
int[] i = arith.getSequence(300);
for(int n=0;n<i.length;n++){
System.out.println(i[n]);
}
}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
c是指C语言,是一种高级的、面向过程的编程语言。C语言由贝尔实验室的丹尼斯·里奇(Dennis Ritchie)在20世纪70年代初发明,被广泛应用于系统软件开发和应用软件开发。C语言具有简洁、灵活、高效的特点,能够直接访问硬件,并且具有较高的可移植性。 C语言的语法与英语比较相似,基本单元是字符,通过组合字符来形成单词和句子。C语言的程序由函数组成,每个函数由语句块构成。C语言提供了丰富的数据型和控制结构,使得程序的编写更加灵活方便。 C语言在操作系统和嵌入式软件开发中得到广泛应用,因为它能够直接访问硬件资源,并且可以高效地管理系统资源。另外,许多应用软件也是使用C语言开发的,比如数据库管理系统、图形界面库等。 C语言的优点有很多。首先,它是一种高效的语言,能够生成高效的机器代码。其次,C语言具有较好的可移植性,可以在不同的操作系统和硬件平台上运行。此外,C语言的语法简洁明了,易于学习和使用。最后,C语言具有广泛的应用领域和丰富的资源,有许多开发工具和库可以供开发者使用。 总的来说,C语言是一种重要的编程语言,它的优点和广泛应用使得它成为程序员必须掌握的一门语言。无论是系统软件开发还是应用软件开发,都可以利用C语言进行高效且灵活的编码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值