不精确数字比较问题

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

--比较大小很自然的想到使用(> 、 < 、 ==),但是这三个运算符只是对于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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值