分数类--运算符重载函数---完整版--gyy

2024-01-10 13:18

本文主要是介绍分数类--运算符重载函数---完整版--gyy,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*
构造一个分数类Fraction,该类中包括分子和分母两个成员数据,并具有下述功能:
(1) 建立构造函数,它能防止分母为零,当分数不是最简形式时进行约分,并避免分母为负数。
(2) 重载加法、减法、乘法以及除法运算符。
(3) 重载关系运算符:>、>=、<、<=、==、!= 
(4) 重载插入">>"和提取"<<"运算符
(5) 重载自加"++"和自减"--"运算符
*/
#include<iostream.h>
#include<stdlib.h>
class Fraction
{
private:int numerator;  //分子 int denominator;  //分母public:Fraction(int n=1,int d=1)  //形参n为分子赋值,形参d为分母赋值{  if(d==0)    // 如果分母为0,显示错误信息,退出程序{cout<<"error!,the denominator is not equal to 0!"<<endl<<"exit program......"<<endl; exit(1); //退出程序}else if(d<0) //  如果分母为负,进行转换,分子分母同时乘以-1,得到分母为正,分子为相反数{ n=(-1)*n;d=(-1)*d;}numerator=n;denominator=d;}void simple()  //对原始分数进行化简,在不是最简形式时进行约分{int k;k=numerator<denominator?numerator:denominator;for(int i=2;i<=k;i++){   while(( numerator%i==0)&&(denominator%i==0))   //分子分母如果同时是i的倍数时,进行化简{ numerator= numerator/i;denominator=denominator/i;}}}void disp() //分数显示{ if(numerator==0){cout<<"0"<<endl;return;}else if (numerator==denominator) {cout<<"1"<<endl;return;}cout<<numerator<<"/"<<denominator<<endl;}void set_numerator() //输入分子{cin>>numerator;}int get_numerator() //获取分子{return numerator;}void set_denominator() //输入分母{int d;cin>>d;if(d!=0)denominator=d;else{cout<<"error!,the denominator is not equal to 0!"<<endl<<"exit program......"<<endl; exit(1); //退出程序}}int get_denominator()  //获取分母{return  denominator;}Fraction operator ++(); //成员函数进行"++"运算符重载,作为前置运算符Fraction operator ++(int);  //成员函数进行"++"运算符重载,作为后置运算符Fraction operator --();   //成员函数进行"--"运算符重载,作为前置运算符Fraction operator --(int);  //成员函数进行"--"运算符重载,作为前置运算符friend Fraction operator +(Fraction a,Fraction b);  //友元函数进行"+"运算符重载,进行分数相加friend Fraction operator -(Fraction a,Fraction b);  //友元函数进行"-"运算符重载,进行分数相减friend Fraction operator *(Fraction a,Fraction b);  //友元函数进行"*"运算符重载,进行分数相乘friend Fraction operator /(Fraction a,Fraction b);  //友元函数进行"+"运算符重载,进行分数相除friend Fraction operator -(Fraction a);  //友元函数进行"-"运算符重载,进行分数求相反数friend int operator > (Fraction a,Fraction b);   //友元函数进行">"运算符重载,进行分数比较friend int operator >=(Fraction a,Fraction b);  //友元函数进行">="运算符重载,进行分数比较friend int operator < (Fraction a,Fraction b);   //友元函数进行"<"运算符重载,进行分数比较friend int operator <=(Fraction a,Fraction b);  //友元函数进行"<="运算符重载,进行分数比较friend bool operator ==(Fraction a,Fraction b); //友元函数进行"=="运算符重载,进行分数比较friend bool operator !=(Fraction a,Fraction b); //友元函数进行"!="运算符重载,进行分数比较friend ostream & operator<<(ostream & output,Fraction & f ); //友元函数进行"<<"运算符重载,进行分数类对象的输出friend istream & operator>>(istream & input,Fraction & f );  //友元函数进行">>"运算符重载,进行分数类对象的输入};Fraction Fraction::operator ++() //成员函数进行"++"运算符重载,作为前置运算符,返回的是已改变值之后的对象
{numerator=numerator+denominator;return (* this); //返回自加后的对象
}Fraction Fraction::operator ++(int) //成员函数进行"++"运算符重载,作为后置运算符,返回的是改变值之前的对象
{Fraction temp=(*this);numerator=numerator+denominator;return temp;  //返回自加前的对象
}Fraction Fraction::operator --()  //成员函数进行"--"运算符重载,作为前置运算符,返回的是已改变值之后的对象
{numerator=numerator-denominator;return (* this); //返回自减后的对象
}Fraction Fraction::operator --(int)  //成员函数进行"--"运算符重载,作为前置运算符,返回的是改变值之前的对象
{Fraction temp=(*this);numerator=numerator-denominator;return temp;  //返回自减前的对象
}Fraction operator + (Fraction a,Fraction b)
{   Fraction temp;temp.numerator=(a.numerator*b.denominator)+b.numerator*a.denominator;temp.denominator=a.denominator*b.denominator;temp.simple();return temp;
}Fraction operator -(Fraction a,Fraction b)
{   Fraction temp;temp.numerator=(a.numerator*b.denominator)-b.numerator*a.denominator;temp.denominator=a.denominator*b.denominator;temp.simple();return temp;
}Fraction operator -(Fraction a)
{   Fraction temp;temp.numerator=a.numerator*(-1);temp.denominator=a.denominator;temp.simple();return temp;
}Fraction operator *(Fraction a,Fraction b)
{   Fraction temp;temp.numerator=a.numerator*b.numerator;temp.denominator=a.denominator*b.denominator;temp.simple();return temp;
}
Fraction operator /(Fraction a,Fraction b)
{   Fraction temp;temp.numerator=a.numerator*b.denominator;temp.denominator=a.denominator*b.numerator;temp.simple();return temp;
}int operator >(Fraction a,Fraction b)
{return (float)a.numerator/(float)a.denominator>(float)b.numerator/(float)b.denominator;}int operator >=(Fraction a,Fraction b)
{return (float)a.numerator/(float)a.denominator>=(float)b.numerator/(float)b.denominator;}int operator <(Fraction a,Fraction b)
{return (float)a.numerator/(float)a.denominator<(float)b.numerator/(float)b.denominator;}int operator <=(Fraction a,Fraction b)
{return (float)a.numerator/(float)a.denominator<=(float)b.numerator/(float)b.denominator;}bool operator ==(Fraction a,Fraction b)
{return a.numerator*b.denominator==b.numerator*a.denominator;}bool operator !=(Fraction a,Fraction b)
{return a.numerator*b.denominator!=b.numerator*a.denominator;}ostream & operator<<(ostream & output,Fraction & f )
{if(f.numerator==0){output<<"0"<<endl;return output;}else if (f.numerator==f.denominator) {output<<"1"<<endl;return output;}output<<f.numerator<<"/"<<f.denominator<<endl;return output;
}istream & operator>>(istream & input,Fraction & f )
{cout<<"input the numerator of fraction: "<<endl; input>>f.numerator;cout<<"input the  denominator of fraction: "<<endl; input>>f.denominator;return input;
}int main ()
{Fraction p1(3,5),p2(12,16),p3;   //定义Fraction类对象cout<<"p1=";p1.disp();    //显示p1的值p1.simple( );  //对p1进行化简cout<<"after simple"<<'\t';cout<<"p1=";p1.disp();    //显示p1的值cout<<"p2=";p2.disp();     //显示p2的值p2.simple( );  //对p2进行化简cout<<"after simple"<<'\t';cout<<"p2=";  p2.disp();  //显示p2的值p3=p1+p2;    //调用+运算符重载函数进行2个Fraction对象的相加cout<<"p1+p2=";p3.disp();p3=p1-p2;    //调用-运算符重载函数进行2个Fraction对象的相减cout<<"p1-p2=";  p3.disp();p3=p1*p2;   //调用*运算符重载函数进行2个Fraction对象的相乘cout<<"p1*p2=";p3.disp();p3=p1/p2;   //调用/运算符重载函数进行2个Fraction对象的相除cout<<"p1/p2=";p3.disp(); p3=-p1;    //调用-运算符重载函数进行1个Fraction对象的求反cout<<"-p1=";p3.disp();if(p1==p2)   //调用==运算符重载函数进行2个Fraction对象的相等比较cout<<"p1=p2"<<endl;if(p1!=p2)   //调用!=运算符重载函数进行2个Fraction对象的不相等比较cout<<"p1!=p2"<<endl;if(p1>p2)   //调用>运算符重载函数进行2个Fraction对象的大于比较cout<<"p1>p2"<<endl;if(p1>=p2)   //调用>=运算符重载函数进行2个Fraction对象的大于等于比较cout<<"p1>=p2"<<endl;if(p1<p2)    //调用<运算符重载函数进行2个Fraction对象的小于比较cout<<"p1<p2"<<endl;if(p1<=p2)   //调用<=运算符重载函数进行2个Fraction对象的小于等于比较cout<<"p1<=p2"<<endl;p3=p1++;  //调用后自增运算符重载函数cout<<"p3=p1++"<<endl;cout<<"p1=";p1.disp();cout<<"p3=";p3.disp();p3=p1--;   //调用后自减运算符重载函数cout<<"p3=p1--"<<endl;cout<<"p1=";p1.disp();cout<<"p3=";p3.disp();p3=++p2;   //调用前自增运算符重载函数cout<<"p3=++p2"<<endl;cout<<"p2=";p2.disp();cout<<"p3=";p3.disp();p3=--p2; //调用前自减运算符重载函数cout<<"p3=--p2"<<endl;cout<<"p2=";p2.disp();cout<<"p3=";p3.disp();cout<<endl<<endl;//利用成员函数重新为分数类对象各个成员赋值cout<<"input the numerator and denominator of p1 :";p1.set_numerator();  //为p1的分子赋值p1.set_denominator();  //为p1的分母赋值cout<<"p1=";p1.disp();  //显示p1的值p1.simple();  //对p1进行化简cout<<"after simple"<<'\t';cout<<"p1="; p1.disp();  //显示p1的值cout<<"input the numerator and denominator of p2 :";p2.set_numerator();   //为p2的分子赋值p2.set_denominator();   //为p2的分母赋值cout<<"p2=";p2.disp();  //显示p2的值p2.simple();  //对p2进行化简cout<<"after simple"<<'\t';cout<<"p2=";p2.disp();   //显示p2的值 p3=p1+p2; cout<<"p1+p2=";p3.disp();p3=p1-p2;cout<<"p1-p2=";p3.disp();p3=p1*p2; cout<<"p1*p2=";p3.disp();p3=p1/p2; cout<<"p1/p2=";p3.disp();p3=-p1;cout<<"-p1=";p3.disp();if(p1==p2) cout<<"p1=p2"<<endl;if(p1!=p2) cout<<"p1!=p2"<<endl;if(p1>p2)cout<<"p1>p2"<<endl;if(p1>=p2)cout<<"p1>=p2"<<endl;if(p1<p2) cout<<"p1<p2"<<endl;if(p1<=p2) cout<<"p1<=p2"<<endl; cout<<endl<<endl;//通过<<和>>运算符重载进行Fraction类对象的输入和输出cout<<"input p1"<<endl;cin>>p1;  //利用>>运算符重载函数进行p1对象的输入cout<<"p1="<<p1;  //利用<<运算符重载函数进行p1对象的输出p1.simple();   //对p2进行化简cout<<"after simple"<<'\t';cout<<"p1="<<p1;   //利用<<运算符重载函数进行p1对象的输出cout<<"input p2"<<endl;cin>>p2;   //利用>>运算符重载函数进行p2对象的输入cout<<"p2="<<p2;  //利用<<运算符重载函数进行p2对象的输出p2.simple();   //对p2进行化简cout<<"after simple"<<'\t';cout<<"p2="<<p2;  //利用<<运算符重载函数进行p2对象的输出return 0;}


这篇关于分数类--运算符重载函数---完整版--gyy的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590935

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

Unity3D 运动之Move函数和translate

CharacterController.Move 移动 function Move (motion : Vector3) : CollisionFlags Description描述 A more complex move function taking absolute movement deltas. 一个更加复杂的运动函数,每次都绝对运动。 Attempts to

【重学 MySQL】十九、位运算符的使用

【重学 MySQL】十九、位运算符的使用 示例检查权限添加权限移除权限 在 MySQL 中,位运算符允许你直接在整数类型的列或表达式上进行位级操作。这些操作对于处理那些需要在二进制表示上进行直接修改或比较的场景特别有用,比如权限管理、状态标记等。 &(位与) 对两个数的二进制表示进行位与操作。只有两个相应的二进制位都为 1 时,结果的该位才为 1,否则为 0。 |(位

C语言程序设计(数据类型、运算符与表达式)

一、C的数据类型 C语言提供的数据类型: 二、常量和变量 2.1常量和符号常量 在程序运行过程中,其值不能被改变的量称为常量。 常量区分为不同的类型: 程序中用#define(预处理器指令)命令行定义变量将代表常量,用一个标识符代表一个常量,称为符合常量。 2.2变量 变量代表内存中具有特定属性的一个存储单元,用来存放数据,在程序运行期间,这些值是可以 改变的。 变

✨机器学习笔记(二)—— 线性回归、代价函数、梯度下降

1️⃣线性回归(linear regression) f w , b ( x ) = w x + b f_{w,b}(x) = wx + b fw,b​(x)=wx+b 🎈A linear regression model predicting house prices: 如图是机器学习通过监督学习运用线性回归模型来预测房价的例子,当房屋大小为1250 f e e t 2 feet^