- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构实验-分数的输入输出、化简及运算
分数的输入输出、化简及运算实验目的建立分数类,实现分数的输入,小数与整数到分数的转化,分数的四则运算,分数的大小比较。并将输入后转为的分数化简,然后以分数形式输出化简后的数。采用辗转相除法与另外一个分数化简的方法,并比较这两种分数化简方式的效率(比较的是化简所用时间)。回顾c++相关知识。实验内容建立分数类,将输入的有理数转为分数,并将分数化简为最简真分数。同时,重载运算符,重载的运算符有“”,“”,“+”,“-”,“*”,“/”,“”,“=”,“”,“=”,“==”,“!=”,分别实现分数类数的输入输出,四则运算,比较大小。在化简过程中,实现两种算法对分数的化简,并对两种算法进行效率比较(比较方式是比较两个算法化简分数所用时间。设计与编码本实验用到的理论知识类的定义与封闭性,运算符的重载知识,各类函数的使用(比如将数组化为整数的atoi()函数),以及简单的c++编程知识。算法设计建立头文件头文件中有分数类,及一些函数的声明。#ifndef Fraction_H#includeiostream#includeistream#includecmath#includemath.h#includetime.h#includestdlib.h#includestring#includectype.h#includestdio.husing namespace std;void simplify(int numerator,int denominator);//分数的化简void simplify_other(int numerator,int denominator);//分数化简void testSimplify(int num,int den);void menu();//界面class Fraction//分数类{public:Fraction(int Numerator=0,intDenominator=1):numerator(Numerator),denominator(Denominator){}Fraction(constFraction f):numerator(f.numerator),denominator(f.denominator){}void simplify();//分数化简,辗转相除法void simplif_other();//分数化简,其他方法bool strFra();//对输入的“数”处理化成分数,并将分数化简char *getstr(){return str;}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 istream operator (istream,Fraction);friend ostream operator (ostream,const Fraction);friend bool operator =(Fraction f1,Fraction f2);friend bool operator =(Fraction f1,Fraction f2);friend bool operator (Fraction f1,Fraction f2);friend bool operator (Fraction f1,Fraction f2);friend bool operator ==(Fraction f1,Fraction f2);friend bool operator !=(Fraction f1,Fraction f2);friend void compute(const Fraction f_num,const string op,const Fraction s_num);//实现分数的大小比较private:char str[1024];//将输入的存在字符串中int numerator;//分子int denominator;//分母void getStrBeforeChar(char *str,char c,char *substr);void getStrAfterChar(char *str,char c,char *substr);bool checkErr(char *str);/、查错};class Int//整数类{public:Int(int i=1):integer(i){
文档评论(0)