zoukankan      html  css  js  c++  java
  • Java程序设计-有理数类的设计

    1.有理数类代码:

    
    public class RationalNum {
    	private int numerator = 0;
    	private int denominator = 1;
    
    	public int getnumerator() {
    		return numerator;
    	}
    
    	public int getdenominator() {
    		return denominator;
    	}
    
    	public RationalNum() {
    		this.numerator = 0;
    		this.denominator = 1;
    	}
    
    	public RationalNum(int numerator, int denominator) { // 以分子分母形式构造
    		if (denominator == 0) {
    			System.out.println("Denominator cannot be zero!");
    			System.exit(1);
    		} else if (numerator == 0) {
    			this.numerator = 0;
    			this.denominator = 1;
    		}
    		int gcd = GCD(numerator, denominator);
    		this.numerator = numerator / gcd;
    		this.denominator = denominator / gcd;
    	}
    
    	public int GCD(int num1, int num2) {               // 辗转相除法获取最大公约数
    		if (num1 < num2) {
    			int k = 0;
    			k = num1;
    			num1 = num2;
    			num2 = k;
    		}
    		return num1 % num2 == 0 ? num2 : GCD(num2, num1 % num2);
    	}
    
    	public RationalNum(Double num) {                  // 输入小数形式构造
    		String str = num.toString();
    		int index = str.indexOf('.');
    		int den = (int) Math.pow(10, str.length() - index);
    		int nrt = (int) (num * den);
    		int gcd = 0;
    		if (nrt < 0) {
    			gcd = GCD(-nrt, den);
    		} else {
    			gcd = GCD(nrt, den);
    		}
    		this.numerator = nrt / gcd;
    		this.denominator = den / gcd;
    	}
    
    	public RationalNum(String str) {                 // 输入字符串构造
    		Double num = Double.parseDouble(str);
    		int index = str.indexOf('.');
    		if (index == -1) {
    			this.numerator = Integer.parseInt(str);
    			this.denominator = 1;
    			return;
    		}
    		int den = (int) Math.pow(10, str.length() - index);
    		int nrt = (int) (num * den);
    		int gcd = 0;
    		if (nrt < 0) {
    			gcd = GCD(-nrt, den);
    		} else {
    			gcd = GCD(nrt, den);
    		}
    		this.numerator = nrt / gcd;
    		this.denominator = den / gcd;
    	}
    
    	public RationalNum add(RationalNum a) {          //加法
    		int nrt = a.numerator * this.denominator + a.denominator * this.numerator;
    		int den = a.denominator * this.denominator;
    		RationalNum num = new RationalNum(nrt, den);
    		return num;
    	}
    
    	public RationalNum minus(RationalNum a) {        //减法
    		int nrt = this.numerator * a.denominator - a.numerator * this.denominator;
    		int den = a.denominator * this.denominator;
    		RationalNum num = new RationalNum(nrt, den);
    		return num;
    	}
    
    	public RationalNum mulitply(RationalNum a) {    //乘法
    		int nrt = this.numerator * a.numerator;
    		int den = this.denominator * a.denominator;
    		RationalNum num = new RationalNum(nrt, den);
    		return num;
    	}
    
    	public RationalNum divide(RationalNum a) {      //除法
    		int nrt = this.numerator * a.denominator;
    		int den = this.denominator * a.numerator;
    		RationalNum num = new RationalNum(nrt, den);
    		return num;
    	}
    
    	public RationalNum abs() {                      //求绝对值
    		int nrt=0,den=1;
    		if(this.numerator<0) {
    			nrt=-this.numerator;
    		}
    		if(this.denominator<0) {
    			den=-this.denominator;
    		}
    		RationalNum num=new RationalNum(nrt,den);
    		return num;
    	}
    	 
    	public boolean equals(RationalNum a) {         //比较两个数是否相等
    		if(this.divide(a).toString().equals("1")) return true;
    		else return false;
    	}
    
            public RationalNum returnLargerNum(RationalNum a) {     //返回两个数中较大的数
        	       RationalNum num =new RationalNum(0,1);
        	       num=this.minus(a);
        	      if(num.intValue()<0)
        	      {
        		   return a;
        	      }
        	      else {
        		   return this;
        	      }
            }
        
            public int intValue() {			              //转化为int类型
    		return (int) this.numerator / this.denominator;
    	}
    
    }
    
    
    
    

    2.测试代码

    
    
    package Main;
    import rational.RationalNum;
    public class Main {
    
    	public static void main(String[] args) {
    		int x1=-2,y1=5;
    		int x2=3,y2=7;
    		double x=3.4;
    		int n=3,m=0;
    		String num="66.66";
    		
    		RationalNum a=new RationalNum(x1,y1);   //-2/5
    		RationalNum b=new RationalNum(x2,y2);   //3/7
    		RationalNum c=new RationalNum(x);
    		RationalNum d=new RationalNum(num);	
    		
    		System.out.println("a="+a.toString()+" ; "+"b="+b.toString()+" ; "+"c="+c.toString()+" ; "+"d="+d.toString());
    		System.out.println("a + b = "+a.add(b).toString());
    		System.out.println("a - b = "+a.minus(b).toString());
    		System.out.println("a * b = "+a.mulitply(b).toString());
    		System.out.println("a / b = "+a.divide(b).toString());
    		System.out.println("Absolute value of a = "+a.abs().toString());
    		System.out.println("The nth power of a = "+a.pow(a, n));
    		System.out.println("The int type of a is "+a.intValue());
    		System.out.println("The double type of a is "+a.doubleValue());
    		System.out.println("The larger number of "+a.toString()+" and "+b.toString()+" is "+a.returnLargerNum(b));
    		System.out.println("Is "+a.toString()+" and "+b.toString()+" the same? "+a.equals(b));
    	}
    
    }
    
    
    

    测试结果:


    3.尝试描述怎么与c语言的有理数代码相比较,为什么你设计的类更加面向对象?

    • C语言强调的是过程,在写代码是更侧重函数的设计编写来实现过程,而在JAVA中强调的是根据对象属性和目标来编写代码,如何让属性间相互联系,如何更好封装是考虑的重点。

    4.尝试从代码复用的角度来描述你设计的有理数类。从几个方面讨论。

    <1>别人如何复用你的代码?

    • 通过import关键字导入包rational中的类RationalNum。

    <2>别人的代码是否依赖你的有理数类的属性?当你的有理数类的属性修改时,是否会影响他人调用你有理数类的代码?

    • (1)是。(2)是,当我将类中方法的入参修改后,其他人想要用这个类也要做出相应修改。

    <3>有理数类的public方法是否设置合适?为什么有的方法设置为private?

    • (1)合适,因为这样方便复用,而且在别的包也能调用。(2)有的方法(例如GCD)设置成private是因为获取最大公约数一般在化简分数时才有较大用处,外界一般不需要调用。
  • 相关阅读:
    2018年蓝桥杯java b组第五题
    2018年蓝桥杯java b组第四题
    2018年蓝桥杯java b组第三题
    2018年蓝桥杯java b组第二题
    2018年蓝桥杯ava b组第一题
    java算法基础范例
    2015年蓝桥杯java b组第十题
    第六届蓝桥杯java b组第8题
    MySQL之数据表(五)
    MySQL数据类型(四)
  • 原文地址:https://www.cnblogs.com/19wangluo-Lishaoqiang/p/13766798.html
Copyright © 2011-2022 走看看