算法练习——C++CH 08 01

问题描述

  已知一个有理数类Zrf_Ratio,实现如下的操作符重载形式:
  friend std::ostream&operator<<(std::ostream&, const zrf_Ratio&);//输出最简分数
  friend std::istream&operator>>(std::istream&, zrf_Ratio&);
  friend bool operator==(const zrf_Ratio&, constzrf_Ratio&);
  friend bool operator<(const zrf_Ratio&, constzrf_Ratio&);

测试

  测试时主程序会输入四个整数a, b, c, d,表示两个分数a/b和c/d。要求输出最简分数以及两个分数相等和大小的比较结果。

样例输入

1 7 26 25

样例输出

zrf is:1/7; sshis:26/25
(zrf==ssh) is:0;(zrf<ssh) is:1

 

C++代码如下:

ostream& operator<<(ostream&os, const zrf_Ratio& zrf_Ratio) { 
   os << zrf_Ratio.num << "/" <<zrf_Ratio.den; 
   return os; 
} 
 
istream& operator>>(istream&in, zrf_Ratio& zrf_Ratio) { 
   in >> zrf_Ratio.num >> zrf_Ratio.den; 
   return in; 
} 
 
bool operator==(const zrf_Ratio&zrf_Ratio1, const zrf_Ratio& zrf_Ratio2) { 
   if (zrf_Ratio1.num == zrf_Ratio2.num && 
       zrf_Ratio1.den == zrf_Ratio2.den) { 
       return 1; 
   } 
   return 0; 
} 
 
bool operator<(const zrf_Ratio&zrf_Ratio1, const zrf_Ratio& zrf_Ratio2) { 
   if (zrf_Ratio1.num * 1.0 / zrf_Ratio1.den < 
       zrf_Ratio2.num * 1.0 / zrf_Ratio2.den) { 
       return 1; 
   } 
   return 0; 
}  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值