△【OJ】(二)---C---分数类的四则运算



题目要求如下:


-----

------------------------------------------------------------------------------------------------------------------------------------------

代码如下:

/*
 * Copyright (c) 2013, 烟台大学计算机学院
 * All rights reserved.
 * 作    者:  沈远宏
 * 完成日期:2014 年 06月27日
 * 版 本 号:v1.0
 * 问题描述:Description
编写分数类Fraction,实现两个分数的加、减、乘和除四则运算。主函数已给定。
Input
每行四个数,分别表示两个分数的分子和分母,以0 0 0 0 表示结束。
Output
空格分隔的两个分数的减和除的结果。

*/#include <iostream>
using namespace std;
class Fraction
{
private:
    int deno;//分母
    int nume;//分子
    int k;//整数部分
public:
    void output();
    void set(int de,int nu);
    void simpilify();
    friend istream& operator>>(istream& cin,Fraction &f);
    friend Fraction operator+(Fraction f1,Fraction f2);
    friend Fraction operator-(Fraction f1,Fraction f2);
    friend Fraction operator*(Fraction f1,Fraction f2);
    friend Fraction operator/(Fraction f1,Fraction f2);
    friend bool operator==(Fraction f,int j);

};
void Fraction::output()
{
       if(k==0)
       {
           cout<<nume<<"/"<<deno;
       }
       else
       {
           cout<<k;
       }
}
void Fraction::set(int de,int nu)
{
     deno=de;
     nume=nu;
}
void Fraction::simpilify()
{
    int t,r,x=nume,y=deno;
    if(nume<0)x=-x;
    if(deno<0)y=-y;
    if(x<y)t=x,x=y,y=t;
    while(y!=0)
    {   r=x%y;
        x=y;
        y=r;
    }
   deno=deno/x;
   nume=nume/x;
   if(deno<0)
   {
       deno=-deno;
       nume=-nume;
   }
   if(nume==deno)
   {
       k=1;
   }
   else if(nume==(-deno))
   {
       k=-1;
   }
   else
   {
       k=0;
   }

}
istream& operator>>(istream& cin,Fraction &f)
{
      cin>>f.nume>>f.deno;
      return cin;
}
Fraction operator+(Fraction f1,Fraction f2)
{
    Fraction f3;
    f3.deno=f1.deno*f2.deno;
    f3.nume=f1.deno*f2.nume+f1.nume*f2.nume;
    f3.simpilify();
    return f3;
}
Fraction operator-(Fraction f1,Fraction f2)
{
    Fraction f3;
    f3.deno=f1.deno*f2.deno;
    f3.nume=f1.nume*f2.deno-f1.deno*f2.nume;
    f3.simpilify();
    return f3;
}
Fraction operator*(Fraction f1,Fraction f2)
{
    Fraction f3;
    f3.nume=f1.nume*f2.nume;
    f3.deno=f1.deno*f2.deno;
    f3.simpilify();
    return f3;
}
Fraction operator/(Fraction f1,Fraction f2)
{
    Fraction f3;
    f3.nume=f1.nume*f2.deno;
    f3.deno=f1.deno*f2.nume;
    f3.simpilify();
    return f3;
}
bool operator==(Fraction f,int j)//
{
    bool i=false;
    if(f.deno==0&&f.nume==0)
    {
        i=true;
    }
    return i;
}
int main()
{
    Fraction f1,f2,f3;
    while(cin>>f1>>f2)
    {
        if(f1==0&&f2==0)
            break;
        f3=f1-f2;
        f3.output();
        cout<<" ";
        f3=f1/f2;
        f3.output();
        cout<<endl;
    }
    return 0;
}




运行结果:


OJ要求结果输出例样:


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值