您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 项目/工程管理 > 实验12-运算符重载
实验12运算符重载(2)牛旭艳智能二班20110807201一、实验目的1、进一步理解运算符重载,运用成员函数和友元函数等方法实现运算符的重载。二、实验内容1、重载函数调用运算符(),将以下的二维数组的下标表示方法:chessBoard[row][column]改为常用的表示方法:chessBoard(row,column)2、重载下标运算符使之返回集合中最大的元素、次最大的元素以及第三大的元素。3、开发多项式类Polynomial,多项式的每一项用数组表示,每项包含一个系数和一个指数。例如:2x4的指数为4,系数为2。请开发一个完整的Polynomial类,包括构造函数、析构函数以及get函数和set函数。该类还要提供下述重载的运算符(分别使用成员函数和友元函数):1)重载加法运算符+,将两个多项式相加;2)重载减法运算符-,将两个多项式相减;3)重载赋值运算符=,将一个多项式赋给另外一个多项式;4)重载乘法算符*,将两个多项式相乘;5)重载加法赋值运算符+=、减法赋值运算符-=以及乘法赋值运算符*=。4.设计一个日期类Date,,要求:(1)包含年(year)、月(month)和日(day)私有数据成员。(2)包含构造函数,重载关于一日期加上天数的加法运算符+、重载关于一日期减去天数的减加运算符-、重载输出运算符与输入运算符等。提示:由于各C++编译器对于重载输入/出运算符为友元的兼容性都存在问题,最好重载输入/出运算符不声明为成员函数与友元函数,而声明一般函数,为编程更方便,可增加一些成员函数,比如:voidSetYear(inty);//设置年intSetMonth(intm);//设置月intSetDay(intd);//设置日intGetYear()const;//返回年intGetMonth()const;//返回月intGetDay()const;//返回日staticintIsLeapyear(inty);//判断年份y是否为润年staticintGetDays(inty);//年份y的天数staticintGetDays(constDate&d);//日期d当前月份的天数staticintDateToNum(constDate&d);//返回从公元1年1月1日起的天数staticDateNumToDate(intn);//由从公元1年1月1日起的天数返回日期润年条件:年份能被4整除,并且年份不能被100整除,或者年份能被400整除润年天数:366平年天数:365润年2月份天数:29平年2月份天数:285.设计一个时间类Time,要求:(1)包含时(hour)、分(minute)和秒(second)私有数据成员。(2)包含构造函数,重载关于一时间加上另一时间的加法运算符+、重载关于一时间减去另一时间的减加运算符-、重载输出运算符与输入运算符等。提示:可仿照第4题编程实现,可将时间转换成秒数,将秒数转成时间进行辅助编程。时间转换成秒数:秒数=时*3600+分*60+秒秒数转换成时间:时=秒数/3600分=(秒数-时*3600)/60秒=秒数%60为编程更方便,可增加一些成员函数,比如:voidSetHour(inthh);//设置小时voidSetMinute(intmm);//设置分钟voidSetSecond(intss);//设置秒intGetHour()const;//返回小时intGetMinute()const;//返回分钟intGetSecond()const;//返回秒三、实验程序及结果1、#includeiostreamusingnamespacestd;classchessBoard{private:inta[2][2];public:chessBoard(inty,intb,intc,intd){a[0][0]=y;a[0][1]=b;a[1][0]=c;a[1][1]=d;}int&operator()(intb,intc);};int&chessBoard::operator()(intb,intc){returna[b][c];}intmain(){chessBoardv(1,2,3,4);v(0,1)=v(1,0);coutv(0,1)endl;return0;}2、#includeiostream.hclassxiabiao{public:xiabiao()//构造函数赋予数组初值{for(inti=0;i10;i++)if(i5)jihe[i]=(-1)*2*i;elsejihe[i]=i+3;cout所有元素:endl;for(i=9;i=0;i--)coutjihe[i]\t;}int&operator[](inta){intt;for(inti=0;i10;i++)//冒泡排序大的放前面for(intj=0;j9-i;j++){if(jihe[j]jihe[j+1]){t=jihe[j];jihe[j]=jihe[j+1];jihe[j+1]=t;}}returnjihe[a-1];}private:intjihe[10];};intmain(){xiabiaoxi;cout最大的为:xi[1]endl;cout第二的为:xi[2]endl;cout第三的为:xi[3]endl;return0;}3、#includeiostream.h#includeiomanip.hclassPolynomial{public:Polynomial();Polynomialoperator+(constPolynomial&)const;Polynomialoperator-(constPolynomial&)const;Polynomialoperator*(constPolynomial&);Polynomial&operator+=(constPolynomial&);Polynomial&operator-=(constPolynomial&);Polynomial&operator*=(constPolynomial&);voidEnterTerms();//输入函数voidPrintPolynomial()const;//打印函数private:intexponents[100];intcoefficients[100];voidpolynomialCombine(Polynomial&);//合并同类项};Polynomial::Polynomial(){for(inti=0;i100;i++)//置零{coefficients[i]=0;exponents[i]=0;}}voidPolynomial::PrintPolynomial()const//输出函数{intstart;//输出累加系数boolzero=false;if(coefficients[0])//常数存在{coutcoefficients[0];start=1;zero=true;}else{if(coefficients[1]){coutcoefficients[1]'x';//常量不存在,输出指数为1的项if((exponents[1]!=0)&&(exponents[1]!=1))cout'^'exponents[1];zero=true;}start=2;}for(intx=start;x100;x++)//输出其他各项if(coefficients[x]!=0){coutsetiosflags(ios::showpos)coefficients[x]resetiosflags(ios::showpos)'x';if((exponents[x]!=0)&&(exponents[x]!=1))cout'^'exponents[x];zero=true;}if(!zero)//多项式为空cout'0';coutendl;}PolynomialPolynomial::operator+(constPolynomial&r)const{Polynomialtemp;boolexponentExists;temp.coefficients[0]=coefficients[0]+r.coefficients[0];//计算常量之和for(ints=1;(s100)&&(r.exponents[s]!=0);s++){temp.coefficients[s]=r.coefficients[s];temp.exponents[s]=r.exponents[s];}for(intx=1;x100;x++)//计算其他各项之和{exponentExists=false;for(intt=1;(t100)&&(!exponentExists);t++)if(exponents[x]==temp.exponents[t]){temp.coefficients[t]+=coefficients[x];exponentExists=true;}if(!exponentExists){temp.exponents[s]=exponents[x];temp.coefficients[s]+=coefficients[x];s++;}}returntemp;}Polynomial&Polynomial::operator+=(constPolynomial&r){*this=*this+r;return*this;}PolynomialPolynomial::operator-(constPolynomial&r)const{Polynomialtemp;boolexponentExists;temp.coefficients[0]=coefficients[0]-r.coefficients[0];for(ints=1;(s100)&&(exponents[s]!=0);s++){temp.coefficients[s]=coefficients[s];temp.exponents[s]=exponents[s];}for(intx=1;x100;x++){exponentExists=false;for(intt=1;(t100)&&(!exponentExists);t++)if(r.exponents[x]==temp.exponents[t]){temp.coefficients[t]-=r.coefficients[x];exponentExists=true;}if(!exponentExists){temp.exponents[s]=r.exponents[x];temp.coefficients[s]-=r.coefficients[x];s++;}}returntemp;}Polynomial&Polynomial::operator-=(constPolynomial&r){*this=*this-r;return*this;}PolynomialPolynomial::operator*(constPolynomial&r){Polynomialtemp;ints=1;for(intx=0;(x100)&&(x==0||coefficients[x]!=0);x++)for(inty=0;(y100)&&(y==0||r.coefficients[y]!=0);y++)if(coefficients[x]*r.coefficients[y])if((exponents[x]==0)&&(r.exponents[y]==0))temp.coefficients[0]+=coefficients[x]*r.coefficients[y];else{temp.coefficients[s]=coefficients[x]
本文标题:实验12-运算符重载
链接地址:https://www.777doc.com/doc-6365711 .html