不精确数字比较问题

来源:互联网 发布:mac辣椒红 编辑:程序博客网 时间:2024/05/04 09:15

--排序是编程过程经常遇到的一类问题,同时人们也提出了各种各样的方法来提高排序的性能,以后有时间再复习一下各种排序。本文是解决一下排序之前的比较问题,因为只有比较了大小,才能有依据进行排序嘛。。。

--比较大小很自然的想到使用(> 、 < 、 ==),但是这三个运算符只是对于Int类型的数据、ASCII码中的字符可以实现直接比较,而对于浮点类型、double类型的数据则是行不通的,可以比较大小但不能判断是否相等,因为这种类型的数据在计算机中本来就不是精确存储的,除非你有办法实现运算符的重载。。。吐舌头

--本文给出一种double类型数据判断相等的方法,即设定比较精度,只要可以根据实际需要让两个数相减,然后再与0比较就行啦。。。(low了,贵在知之为知之)

输入形式(自己可以使用double试试):

3
1 2 3
2 3 4
3 4 5

输出形式:(false表示前两个数不大于后面1个数)

Case #1:false
Case #2:true
Case #3:true

import java.util.InputMismatchException;import java.util.Scanner;public class Test { public static void cmp(double a,double b,double c){        double d=a+b-c;        if(d>0.00001){            System.out.println("true");        }        else{            System.out.println("false");        }    }public static void main(String[]args){int N=0;    int i=0;    Scanner sc=new Scanner(System.in);    try{        N=sc.nextInt();    }catch(InputMismatchException e){        e.printStackTrace();    }    if(N<=0||N>10){System.out.println("Input is invalid");return;}    double[]A=new double[N];    double[]B=new double[N];    double[]C=new double[N];    while(i<N){        try{            A[i]=sc.nextDouble();        B[i]=sc.nextDouble();        C[i]=sc.nextDouble();        ++i;           }catch(InputMismatchException e){            e.printStackTrace();        }           }    int j=0;    while(j<N){    System.out.print("Case #"+(j+1)+":");    cmp(A[j],B[j],C[j]);    ++j;    }    }}


0 0
原创粉丝点击