蓝桥杯 算法训练 C++ CH08 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&, const zrf_Ratio&);
  friend bool operator<(const zrf_Ratio&, const zrf_Ratio&);
测试
  测试时主程序会输入四个整数a, b, c, d,表示两个分数a/b和c/d。要求输出最简分数以及两个分数相等和大小的比较结果。
样例输入
1 7 26 25
样例输出
zrf is:1/7; ssh is:26/25

(zrf==ssh) is:0; (zrf<ssh) is:1

这道题开始用java做,一会儿做出来提交才发现原来这是一道c++填空题,不能用java做。

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;    
}    

阅读更多
版权声明: https://blog.csdn.net/hui_1997/article/details/79944856
下一篇蓝桥杯 算法训练 6-1 递归求二项式系数值 (java)
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭