| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 387 人关注过本帖
标题:大家看看
只看楼主 加入收藏
leier1010
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2006-10-27
收藏
 问题点数:0 回复次数:0 
大家看看

我们要求C语言编个程序,实现无限位数的四则运算,我用数组编了,但是不通过,大家能看看吗?还是友人能编吗?
我们明天交作业了,谢谢大家!

这是我编的,但是用的是数组,很难实现无限位数的运算.

#include<stdio.h>
#include<stdlib.h>

int a[10000],b[10000],c[10000];
int ha,hb,hc,ta,tb,tc,s=0;
char symbol;

void init();
void out();
void add();
void del();
void mul();
void dev();
int big();

main()
{
init();
switch(symbol)
{
case '+': {add(); break;}
case '-': {del(); break;}
case '*': {mul(); break;}
case '/': {dev(); break;}
}
out();
system("pause");
return 0;
}

void add()
{
int i,j,k;
int na,nb;
if (ta-ha>tb-hb)
{ tc=ta; hc=ha;}
else
{ tc=tb; hc=hb;}
for (i=tc; i>=hc; i--)
{
if (ta-(tc-i)<ha)
na=0;
else na=a[ta-(tc-i)];
if (tb-(tc-i)<hb)
nb=0;
else nb=b[tb-(tc-i)];
c[i]=na+nb;
}
for (i=tc; i>=hc+1; i--)
if (c[i]>=10)
{ c[i-1]++; c[i]%=10;}
if (c[hc]>=10)
{ hc--; c[hc]=1; c[hc+1]%=10;}
}

void del()
{
int i,j,k;
int t,h,w;
int na,nb;

if (!big())
{ printf("-");
if (ha<hb)
h=ha;
else h=hb;
if (ta>tb)
t=ta;
else
t=tb;
for (i=h; i<=t; i++)
{w=a[i]; a[i]=b[i]; b[i]=w;}
t=ta; h=ha; ta=tb; ha=hb; tb=t; hb=h;
}
for (i=ta; i>=ha; i--)
{
na=a[i];
if (tb-(ta-i)<hb)
nb=0;
else nb=b[tb-(ta-i)];
c[i]=na-nb;
}
tc=ta; hc=ha;
for (i=tc; i>=hc+1; i--)
if (c[i]<0)
{ c[i-1]--; c[i]+=10;}
while (hc<tc && c[hc]==0)
hc++;
}

void mul()
{
int i,j,k,na,nb;
hc=1; tc=(ta-ha+1+tb-hb+1);
for (i=hc; i<=tc; i++)
c[i]=0;
for (i=ta; i>=ha; i--)
for (j=tb; j>=hb; j--)
{
c[tc-(ta-i+tb-j)]+=a[i]*b[j];
}
for (i=tc; i>=hc+1; i--)
if (c[i]>=10)
{c[i-1]+=c[i]/10; c[i]%=10;}
if (c[hc]==0)
hc++;
}

void dev()
{
int i,j,k,na,nb;

while (big())
{
del();
s++;
ha=hc; ta=tc;
for(i=hc; i<=tc; i++)
a[i]=c[i];
}
}


int big()
{
int i;
if (ta-ha>tb-hb)
return 1;
else if (ta-ha<tb-hb)
return 0;
else
for (i=ha; i<=ta; i++)
if (a[i]>b[hb+(i-ha)])
return 1;
else if (a[i]<b[hb+(i-ha)])
return 0;
return 1;
}


void init()
{
char ch;
symbol=getchar();
while (symbol != '+' && symbol != '-' && symbol != '*' && symbol != '/')
symbol=getchar();
ha=1; ta=0;
ch=getchar();
while (ch!='#')
{
if (ch>='0' && ch<='9')
{ ta++; a[ta]=ch-'0';}
ch=getchar();
}

hb=1; tb=0;
ch=getchar();
while (ch!='#')
{
if (ch>='0' && ch<='9')
{ tb++; b[tb]=ch-'0';}
ch=getchar();
}
}

void out()
{
int i;
if (symbol=='/')
printf("%d 余",s);
for (i=hc; i<=tc; i++)
printf("%d",c[i]);
printf("\n");
}

搜索更多相关主题的帖子: include C语言 
2006-10-30 18:53
快速回复:大家看看
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.026290 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved