码迷,mamicode.com
首页 > 其他好文 > 详细

第十周(11.18-11.24)----结对编程----分数计算

时间:2016-11-24 07:40:14      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:sys   技术分享   class   1.2   公约数   turn   编程   代码   mon   

  之前的程序写到可以输出分数的算式,接下来就是要怎么计算这个分式算式。我查阅了资料,目前完成到这个状况,对给定的两个分数计算结果。

  fenshucount里getDinominator是获得分母,getNumerator是获得分子。

  获得最大公约数

 1  public static  int commonDivisor(int x,int y)       //计算2个数的最大公约数。按绝对值计算。  
 2         {  
 3             if(x==0||y==0)  
 4             {  
 5                 return 1;  
 6             }  
 7             int x1;               
 8             int y1;  
 9       
10             x1=(Math.abs(x)>Math.abs(y))?Math.abs(x):Math.abs(y);                //使x1>y1.  
11             y1=(Math.abs(x)>Math.abs(y))?Math.abs(y):Math.abs(x);  
12             int z=1;  
13                 while(z!=0)   
14                 {  
15                 z=x1%y1;  
16                     x1=y1;  
17                     y1=z;  
18                 }   
19             return x1;  
20         }  

 

  实现两个分数相加

1 public fenshucount plus(fenshucount f2)      //加法运算
2   {  
3             int newNumerator=c*f2.getDinominator()+d*f2.getNumerator();  
4             int newDinominator=d*f2.getDinominator();  
5       
6             int maxCommon=commonDivisor(newNumerator,newDinominator);  
7             return new fenshucount(newNumerator/maxCommon,newDinominator/maxCommon);  
8   }  

  实现两个分数相减

1  public fenshucount minus(fenshucount f2)      //减法运算
2    {  
3             int newNumerator=c*f2.getDinominator()-d*f2.getNumerator();  
4             int newDinominator=d*f2.getDinominator();  
5       
6             int maxCommon=commonDivisor(newNumerator,newDinominator);  
7             return new fenshucount(newNumerator/maxCommon,newDinominator/maxCommon);  
8    } 

  代码测试

1 fenshucount f1 = new fenshucount(3,4);

2 fenshucount f2 = new fenshucount(4,5); 

3 System.out.println(f1.plus(f2)); 

  结果

技术分享

 

第十周(11.18-11.24)----结对编程----分数计算

标签:sys   技术分享   class   1.2   公约数   turn   编程   代码   mon   

原文地址:http://www.cnblogs.com/YangXiaomoo/p/6095583.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!