码迷,mamicode.com
首页 > 编程语言 > 详细

实现有理数类(Java)

时间:2015-05-20 20:04:17      阅读:245      评论:0      收藏:0      [点我收藏+]

标签:

  1. /*Java中没有提供表示有理数的类。
  2. 有理数类
  3. */
  4. public class Rational {
  5. private long numerator = 0; //分子
  6. private long denominator = 1; //分母
  7. //构造函数
  8. public Rational() {
  9. this(0,1);
  10. }
  11. public Rational(long numerator, long denominator) {
  12. long gcd = gcd(numerator,denominator);
  13. this.numerator= ((denominator>0)? 1 : -1)*numerator / gcd;
  14. this.denominator=Math.abs(denominator)/gcd;
  15. }
  16. //求最大公约数,便于简化有理数
  17. public static long gcd(long n,long d){
  18. long n1=Math.abs(n);
  19. long n2=Math.abs(d);
  20. int gcd=1;
  21. for(int k=1;k<=n1&&k<=n2;k++){
  22. if(n1%k==0&&n2%k==0){
  23. gcd=k;
  24. }
  25. }
  26. return gcd;
  27. }
  28. //生成器
  29. public long getNumerator(){
  30. return numerator;
  31. }
  32. public long getDenominator(){
  33. return denominator;
  34. }
  35. //实现加法
  36. public Rational add(Rational secondRational){
  37. long n=numerator*secondRational.getDenominator()+
  38. denominator*secondRational.getNumerator();
  39. long d=denominator*secondRational.getDenominator();
  40. return new Rational(n,d);
  41. }
  42. //实现减法
  43. public Rational subtract(Rational secondRational){
  44. long n=numerator*secondRational.getDenominator()-
  45. denominator*secondRational.getNumerator();
  46. long d=denominator*secondRational.getDenominator();
  47. return new Rational(n,d);
  48. }
  49. //实现乘法
  50. public Rational multiply(Rational secondRational){
  51. long n=numerator*secondRational.getNumerator();
  52. long d=denominator*secondRational.getDenominator();
  53. return new Rational(n,d);
  54. }
  55. //实现除法
  56. public Rational divide(Rational secondRational){
  57. long n=numerator*secondRational.getDenominator();
  58. long d=denominator*secondRational.numerator;
  59. return new Rational(n,d);
  60. }
  61. //重写toString类
  62. public String toString(){
  63. if(denominator==1){
  64. return numerator+"";
  65. }else{
  66. return numerator+"/"+denominator;
  67. }
  68. }
  69. public boolean equals(Object praml){
  70. if((this.subtract((Rational)(praml))).getNumerator()==0){
  71. return true;
  72. }else{
  73. return false;
  74. }
  75. }
  76. public int intValue(){
  77. return (int)doubleValue();
  78. }
  79. public float floatValue(){
  80. return (float)doubleValue();
  81. }
  82. public double doubleValue(){
  83. return numerator*1.0/denominator;
  84. }
  85. public long longValue(){
  86. return (long)doubleValue();
  87. }
  88. //实现Comparable接口,compare方法
  89. public int compareTo(Object o){
  90. if((this.subtract((Rational)o)).getNumerator()>0){
  91. return 1;
  92. }else{
  93. return 0;
  94. }
  95. }
  96. }




实现有理数类(Java)

标签:

原文地址:http://www.cnblogs.com/zeroves/p/4517791.html

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