写了一个利用循环链表进行超大整数四则运算的c程序加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误

来源:学生作业帮助网 编辑:作业帮 时间:2024/05/12 08:11:26
写了一个利用循环链表进行超大整数四则运算的c程序加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误

写了一个利用循环链表进行超大整数四则运算的c程序加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误
写了一个利用循环链表进行超大整数四则运算的c程序
加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误的提示.求高手看下乘法函数哪里有问题,程序太长,只贴出了乘法函数,另外打印函数和main函数会在后面补充,求教,
之前用别的号问了已经,还没有人回答,而且贴程序时漏掉一行代码,那个号已经没分了,所以另开一个问题,希望有人帮帮我.
#include
#define HUNTHOU 10000
typedefstruct node
{
int data;
struct node *next;
}NODE; /*定义链表结构*/
/*输入超长整数,存入链表*/
NODE *inputint(void)
{
NODE *s,*ps,*qs;
struct number
{
int num;
struct number *np;
}*p,*q;
int i,k;
long sum;
char c;
p=NULL; /*指向输入的整数,链首为长整数的最低位,链尾为长整数的最高位*/
while((c=getchar())!='\n'){ /*输入整数,按字符接收数字*/
if(c>='0'&&cnum=c-'0'; /*存入一位整数*/
q->np=p; /*建立指针*/
p=q;
}
}
s=(NODE *)malloc(sizeof(NODE));
s->data=-1; /*建立表求超长整数的链头*/
ps=s;
while(p!=NULL){ /*将接收的临时数据链中的数据换为所要求的标准形式*/
sum=0;i=0;k=1;
while(inum);
i++;
p=p->np;
k=k*10;
}
qs=(NODE*)malloc(sizeof(NODE)); /*申请空间*/
qs->data=sum; /*赋值,建立链表*/
ps->next=qs;
ps=qs;
}
ps->next=s; /*指向头结点*/
return s;
}
/*在u结点插入一个新的NODE,其值为num*/
NODE *insert_after(NODE *u,int num)
{
NODE *v;
v=(NODE*)malloc(sizeof(NODE)); /*申请一个NODE*/
v->data=num; /*赋值*/
u->next=v; /*在u结点后插入一个NODE*/
return v;
}
/*求两个大整数的乘积,并返回指向|(*p)*(*q)|结果的指针*/
NODE *mulint(NODE *p,NODE *q)
{
NODE *pc,*qc,*s,*t;
int i,number,total;
s=(NODE*)malloc(sizeof(NODE)); /*建立存放乘积的链表表头*/
s->data=-1; /*给存放乘积的链表表头赋值-1*/
pc=p->next;
t=s;i=0; /* i为进位 */
while(pc->data!=-1){ /*不是表头*/
qc=q->next;
while(qc->data!=-1){ /*不是表头*/
if(t->next==NULL){
total=pc->data*qc->data+i; /*对应位的积与前次进位的和*/
i=total/HUNTHOU; /*求进位*/
number=total-i*HUNTHOU; /*求出需要存入链表链表中的部分的数值*/
t=insert_after(t,number); /*将部分积存入s指向的链表中*/
}
else{
total=total+pc->data*qc->data+i;
i=total/HUNTHOU;
number=total-i*HUNTHOU;
t=insert_after(t,number);
}
qc=qc->next; /*移动指针*/
}
if(i!=0){
t=insert_after(t,i); /*处理最后一次进位*/
t->next=s; /*指向头结点*/
}
pc=pc->next; /*移动指针*/
}
return s; /*返回指向积的结构指针*/
}
void printint(NODE *s)
{
if(s->next->data!=-1) /*若不是表头,则输出*/
{
printint(s->next); /*递归输出*/
if(s->next->next->data==-1)
printf("%d",s->next->data); /*打印最高位*/
else{
int i,k=10000;
for(i=1;inext->data %(k)/(k/10) );
}
}
}
int main(void)
{
NODE *s1,*s2,*s;
char c;
NODE *inputint(),*insert_after(),*mulint();
do{
printf("Enter s1=");
s1=inputint(); /*输入大整数,存入链表*/
printf("Enter s2=");
s2=inputint();
s=mulint(s1,s2); /*求积*/
printint(s); /*输出结果*/
putchar('\n');
}while(c=getchar()=='\n');
return0;
}

写了一个利用循环链表进行超大整数四则运算的c程序加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误
某些即使小数字运算时却出现内存错误的提示
造成这样的原因很简单,那就是你用小数字运算或无需进位时,运行到这一步时
if(i!=0){
t=insert_after(t,i); /*处理最后一次进位*/
t->next=s; /*指向头结点*/
}
由于不需要进位,所以没执行,导致这一步没执行 “t->next=s; /*指向头结点*/”
所以当执行到这一步
oid printint(NODE *s)
{
if(s->next->data!=-1) /*若不是表头,则输出*/ 由于指针没有回指到头节点,所以这一句会报错

写了一个利用循环链表进行超大整数四则运算的c程序加减法运算没有问题,只是乘法运算时,对于某些数字即使是大整数也可以运算且输出正确结果,但对某些即使小数字运算时却出现内存错误 设计一个程序实现两个任意长的整数的求和运算.基本要求:利用双向循环链表,设计一个实现任意长的整数进行加法运算的演示程序.要求输入和输出每四位一组,组间用逗号隔开.如:1,0000,0000 利用循环,输入一个整数,将各位数字反转后输出 怎样利用LINGO进行循环语句 汽车发动机运用循环流动水进行冷却,是利用了水的什么特性? 急求!利用循环语句编写:对一个正整数,将各位数字反序后的数组成一个整数输出.用C语言循环语句编程.急求! 整数四则运算法则 整数四则运算估算方法 整数四则运算练习题只要整数,现在没分了,只要整数 c++程序:输入一个大整数n然后利用循环搜索k,使得3 k < =n < 3 k+1 输出整数k内容: 输入一个大整数n然后利用循环搜索k,使得3 k < =n < 3 k+1输出整数k 输入说明: 一行一个整数n 输出 小数、整数、分数的四则运算 整数四则运算的运算顺序 C语言的表达式求值该怎么写?用后缀写,目前学了数据结构只会写压栈出栈遍历,怎么才能用栈写一个表达式求值的代码?还希望给一个代码参考下要求如下:•1、能进行+、-、*、/四则运算&# 输入一个整数,求输出小于等于该数的所有素数,C语言问题.看看哪出问题了..不能用两个for循环解决么?我这么写之后总是不对,调试的时候发现第二个for循环总是不循环啊,结果导致很多不是素 输入一个整数,然后输出小于等于该数的所有素数,C语言问题.不能用两个for循环解决么?我这么写之后总是不对,调试的时候发现第二个for循环总是不循环啊,结果导致很多不是素数的也跑进来了 c语言 虚数的四则运算 高手帮帮忙!高手们帮帮忙吧 入门新手实在不会了 用结构体 做一个虚数的四则运算 写add, subtract, multiple, divide四个函数 (麻烦帮忙写一下简单的说明)谢谢 在一个密闭容器内,植物进行光合作用之后生成了氧气消耗了二氧化碳能否再利用生成的氧气进行有氧呼吸如果是不就意味着循环利用了吗,那样的话植物能存活多久,回答好的重重有赏,哈哈 算24点:3 4 -6 10 进行加减乘除四则运算,写3种不同的算式(一个算式中每数只用一算24点:3 4 -6 10 进行加减乘除四则运算,写3种不同的算式(一个算式中每数只用一次)