1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > c语言有理数字符形式 C语言设计实现抽象数据类型有理数基本操作包括有理数的加法 减

c语言有理数字符形式 C语言设计实现抽象数据类型有理数基本操作包括有理数的加法 减

时间:2023-09-22 16:56:46

相关推荐

c语言有理数字符形式 C语言设计实现抽象数据类型有理数基本操作包括有理数的加法 减

满意答案

mkblue

.06.15

采纳率:48%等级:9

已帮助:313人

有理数即分数,

分数的数据类型是很简单的。

另外,求有理数的分子,分母的问题,因为给的有理数只能是有限小数,所以根本没有疑问。

但是如果改成:

求分子分母之和最小的,在一定误差范围内的分数,这个问题才有价值

比如:

0.3333333,如果误差为1e-4

那么1/3明显要比333333/10000000

下面给出一个实现(C++):

struct RatNum

{

int a,b;

static int GCD(int a,int b)

{

if(a<0)a=-a;

if(b<0)b=-b;

if(a==0)return b;

if(b==0)return a;

if(a

{

int c=a;

a=b;

b=c;

}

unsigned int c;

while(c= a % b)

{

a = b ;

b = c;

}

return b;

}

explicit RatNum(int aa=0,int bb=1)

:a(aa),b(bb)

{

}

explicit RatNum(double num,double esp=0.00000001)

{

if(esp<0)esp=-esp;

for(b=1;;b++)

{

a=b*num+.5;

double k=a-b*num;

if(k<0)k=-k;

if(k

}

}

void norm()//约分

{

int c=GCD(a,b);

a/=c;

b/=c;

if(b<0)

{

a=-a;

b=-b;

}

}

RatNum operator/(const RatNum& f)const

{

RatNum d=*this;

d.a*=f.b;

d.b*=f.a;

return d;

}

RatNum operator-()const

{

RatNum ret=*this;

ret.a=-ret.a;

return ret;

}

void operator*=(const RatNum& f)

{

a*=f.a;

b*=f.b;

norm();

}

RatNum operator*(const RatNum& f)const

{

RatNum d=*this;

d*=f;

return d;

}

RatNum operator*(int q)const

{

RatNum d=*this;

d.a*=q;

return d;

}

void operator-=(const RatNum& f)

{

int bb=b;

a*=f.b;

b*=f.b;

a-=f.a*bb;

}

void operator+=(const RatNum& f)

{

int bb=b;

a*=f.b;

b*=f.b;

a+=f.a*bb;

}

void positive()

{

if (a<0)a=-a;

}

bool operator==(int n)

{

return a==n*b;

}

void operator=(int q)

{

a=q;

b=1;

}

};

00分享举报

c语言有理数字符形式 C语言设计实现抽象数据类型有理数基本操作包括有理数的加法 减法 乘法 除法 以及求有理数的分子 分...

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。