山东科技大学OJ Problem I: 分数类之二

文章描述了一个使用C++编写的分数类(Fraction)和整数类(Integer),类中包含构造函数、分子和分母的获取方法以及分数的值的计算。Fraction类还实现了递增运算(前置++和后置++),每次运算分数加1。给定输入后,程序会输出相应的分数和其值。
摘要由CSDN通过智能技术生成
HomeProblemSetStandingStatusStatistics

Problem I: 分数类之二

Time Limit: 1 Sec  Memory Limit: 2 MB
Submit: 445  Solved: 295
[Submit][Status]

Description

         一个分数类(Fraction)对象由两部分组成,分别是分子(numerator)和分母(denominator)。分子和分母均为整数类(Integer)对象,用以存储一个整型数值。

         用C++编写Fraction类和Integer类来完成代码,调用格式见“Append Code”。

Fraction::numerator()取得分子数值。

Fraction:: denominator ()取得分母数值。

Integer::value()取得整数值。

         Fraction类和Integer类的构造函数,根据题意设计。

         在Fraction类上设计递增运算(前置++和后置++),每次运算数值加1。如,“1/2”递增运算后变为“3/2”。

Input

输入为多组。每组包括分子分母两个整数。

Output

Sample Input

3 5 5 3

Sample Output

8/5 8/5=1.6 8/5 13/5=2.6 8/3 8/3=2.66667 8/3 11/3=3.66667

HINT

Append Code

#include <iostream>
#include <string>
#include <cmath>
using namespace std;
class Integer
{public:
    int x;
    Integer(){}
    Integer(int nn):x(nn){}
    Integer(Integer& dd){
        this->x=dd.x;}
    int value()
    {return x;
    }
};
class Fraction
{public:
    Integer n,d;//分子、分母 
    Fraction(Integer& nn,Integer& dd):n(nn),d(dd){}
    Fraction(int a,int b){
        this->n.x=a;this->d.x=b;
    }
    Fraction(Fraction& k){
        this->n=k.n;this->d=k.n;
    }
    Fraction(){}
    Integer& numerator(){
        return n;
    }
    Integer& denominator(){
        return d;
    }
    double value()
    {return (double)1.0*n.x/d.x;
    }
     
    Fraction& operator++()//前置 
    {n.x+=d.x;
    return *this;
    }
     
    Fraction operator++(int)
    {int a=this->n.x,b=this->d.x;
    Fraction kk(a,b);
    this->n.x+=this->d.x;
     
    return kk;
    }
     
    void print(){
        cout<<n.x<<"/"<<d.x<<endl;
    }
};
 
int main()
{
    int n, d;
    while(cin >> n >> d)
    {
        Integer num(n), den(d);
        Fraction f(num, den);
        (++f).print();
        cout << f.numerator().value() << "/" << f.denominator().value() << "=" << f.value() << endl;
        (f++).print();
        cout << f.numerator().value() << "/" << f.denominator().value() << "=" << f.value() << endl;
 
    }
}
 
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值