--排序是编程过程经常遇到的一类问题,同时人们也提出了各种各样的方法来提高排序的性能,以后有时间再复习一下各种排序。本文是解决一下排序之前的比较问题,因为只有比较了大小,才能有依据进行排序嘛。。。
--比较大小很自然的想到使用(> 、 < 、 ==),但是这三个运算符只是对于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;
}
}
}