![](https://iknow-base.cdn.bcebos.com/lxb/notice.png)
c++程序运行时编译和连接没有错误 执行时会出现xx.exe已停止工作
这是一部分代码,功能是实现100位以内长整数的加减法。输入输出要求每四位一组,组间用逗号分隔。加减用不同程序实现,程序要考虑输入数据的符号。#include<stdio....
这是一部分代码,功能是实现100位以内长整数的加减法。输入输出要求每四位一组,组间用逗号分隔。加减用不同程序实现,程序要考虑输入数据的符号。#include <stdio.h>
#include <stdlib.h>
#define LEN sizeof(Number)
typedef struct Number
{
int data;
struct Number *next;
struct Number *prior;
}Number;
void main()
{
void DestroyList(Number *);
void PutNumber(Number *);
Number *GetNumber();
Number *JiaFa(Number *num_1,Number *num_2);
Number *JianFa(Number *num_1,Number *num_2);
Number *number_1, *number_2,*number;
char ch;
printf("Please Enter the First Long Integer:");
number_1=GetNumber();
printf("Put + or -:");
ch=getchar();
fflush(stdin);
printf("Please Enter the Second Long Integer:");
number_2=GetNumber();
if(ch='+')
number=JiaFa(number_1,number_2);
else
if(ch='-')
number=JianFa(number_1,number_2);
printf("\n=\n");
PutNumber(number);
DestroyList(number);
DestroyList(number_1);
DestroyList(number_2);
printf("释放链表\n");
}
Number *GetNumber()
{
Number *p,*q,*List;
char ch;
p=(Number *)malloc(LEN);
List=p;
List->prior=NULL;
List->data=0;
ch=getchar();
while(ch!='\n')
{
if(ch>='0'&&ch<='9')
{
q=(Number *)malloc(LEN);
q->data=ch-'0';
q->next=q;
q->prior=p;
p=q;
}
ch=getchar();
}
p->next=NULL;
List->prior=NULL;
return List;
} 展开
#include <stdlib.h>
#define LEN sizeof(Number)
typedef struct Number
{
int data;
struct Number *next;
struct Number *prior;
}Number;
void main()
{
void DestroyList(Number *);
void PutNumber(Number *);
Number *GetNumber();
Number *JiaFa(Number *num_1,Number *num_2);
Number *JianFa(Number *num_1,Number *num_2);
Number *number_1, *number_2,*number;
char ch;
printf("Please Enter the First Long Integer:");
number_1=GetNumber();
printf("Put + or -:");
ch=getchar();
fflush(stdin);
printf("Please Enter the Second Long Integer:");
number_2=GetNumber();
if(ch='+')
number=JiaFa(number_1,number_2);
else
if(ch='-')
number=JianFa(number_1,number_2);
printf("\n=\n");
PutNumber(number);
DestroyList(number);
DestroyList(number_1);
DestroyList(number_2);
printf("释放链表\n");
}
Number *GetNumber()
{
Number *p,*q,*List;
char ch;
p=(Number *)malloc(LEN);
List=p;
List->prior=NULL;
List->data=0;
ch=getchar();
while(ch!='\n')
{
if(ch>='0'&&ch<='9')
{
q=(Number *)malloc(LEN);
q->data=ch-'0';
q->next=q;
q->prior=p;
p=q;
}
ch=getchar();
}
p->next=NULL;
List->prior=NULL;
return List;
} 展开
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励20(财富值+成长值)
1个回答
展开全部
大致浏览了一下,没有发现明显错误。
这种情况,就需要调试了。F5执行程序,遇到运行警告后中断,通过调用堆栈查看具体问题代码行。之后,通过变量观察、设置断点、单步执行等方式,查找具体问题。
编译链接无误,只是没有语法错误,运行时错误一般都是代码中对内存、指针、句柄的非法操作造成的。
另外,如果没有特殊指定要求,用一个char[100]代替链表指针是个不错的选择,因为在没有类管理的前提下,链表不仅增加了很多程序复杂度,而且还没有达到节省空间和方便灵活的目的。
这种情况,就需要调试了。F5执行程序,遇到运行警告后中断,通过调用堆栈查看具体问题代码行。之后,通过变量观察、设置断点、单步执行等方式,查找具体问题。
编译链接无误,只是没有语法错误,运行时错误一般都是代码中对内存、指针、句柄的非法操作造成的。
另外,如果没有特殊指定要求,用一个char[100]代替链表指针是个不错的选择,因为在没有类管理的前提下,链表不仅增加了很多程序复杂度,而且还没有达到节省空间和方便灵活的目的。
追问
要求必须用线性表实现
来自:求助得到的回答
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |