c-刚学数据结构写了个链表,调试无报错,一运行就显示“main.exe停止运行”。

问题描述

刚学数据结构写了个链表,调试无报错,一运行就显示“main.exe停止运行”。

刚学数据结构,写了个链表,调试无误,一运行就显示“main.exe停止运行”,很头疼,求大神指点。。谢谢~

代码如下:

#include
#include

#define OK 1
#define ERROR 0
#define OVERFLOW -1

define LIST_INIT_SIZE 100 // 线性表存储空间的初始分配量

define LISTINCREMENT 10 // 线性表存储空间的分配增量

typedef int Status;
typedef int ElemType; //定义ElemType类型为int
typedef struct LNode
{
ElemType data; //数据域
struct LNode *next; //指针域
} LNode,*LinkList; //LinkList为Lnode类型的指针

Status InitList(LinkList L)
{
L=NULL;
L=(LinkList)malloc(sizeof(LNode));
if(!L)
exit(OVERFLOW);
L->next=NULL;
return OK;
}

void CreateList(LinkList L,int n)
{
//正位序输入n个元素的值,建立带表头结点的单链表L
LinkList r=NULL,p=NULL;
p = (LinkList)malloc(sizeof(LNode));
int i;
L->next=NULL;
r=L;
for(i=0; i
{
p = (LinkList)malloc(sizeof(LNode));
p->next=NULL;
r->next=p; //插入到表尾
r=p; //r指向新的尾结点
scanf("%d",&p->data);//输入元素值
}
}//CreateList_L

int ListEmpty(LinkList L)
{
//若L为空表,则返回1,否则返回0
if(L->next) //非空
return 0;
else
return 1;
}

Status GetElem(LinkList L,int i,ElemType e)
{
//当第i个元素存在时,其值赋给e并返回OK,否则返回ERROR
LinkList p;
int j;
p=L->next;
j=1; //初始化
while(p&&j
{
//向后扫描,直到p指向第i个元素或p为空
p=p->next;
++j;
}
if(!p || j>i) return ERROR; //第i个元素不存在
e=p->data; //取第i个元素
return OK;
}//GetElem_L

Status LocateElem(LinkList L,ElemType e)
{
LinkList p;
p=L->next;
while(p && p->data!=e)
p=p->next;
return p; //返回L中值为e的数据元素的位置,查找失败返回NULL
}

Status ListInsert(LinkList L,int i,ElemType e)
{
LinkList p;
LNode *s;
int j;
p=L;
j=0;
while(p&&j
{
p=p->next; //寻找第i-1个结点
++j;
}
if(!p||j>i-1)return ERROR; //i大于表长?+?1或者小于1
s=(LinkList)malloc(sizeof(LNode));//生成新结点s
s->data=e; //将结点s的数据域置为e
s->next=p->next; //将结点s插入L中
p->next=s;
return OK;
}//ListInsert_L

Status ListDelete(LinkList L,int i,ElemType e)
{
LinkList p;
int j;
LNode *r;
p=L;
j=0;
while(p->next &&j
{
p=p->next;
++j;
}
if(!(p->next)||j>i-1) return ERROR; //删除位置不合理
r=p->next; //临时保存被删结点的地址以备释放
p->next=r->next; //改变删除结点前驱结点的指针域
e=r->data;
free(r);//释放结点
}//ListDelete_L

void menu()

{
printf("/////////////////////////n");
printf("输出单链表中的各元素值 1n");
printf("在单链表中插入数据元素 2n");
printf("在单链表中删除数据元素 3n");
printf("取出单链表中的数据元素 4n");
printf(" 结束程序 0n");
printf("/////////////////////////n");

}

int main()
{
int n,m,i,e;
LinkList L = NULL,p = NULL;
InitList(L);
printf("请输入元素个数:");
scanf("%d",&n);
printf("依次输入%d个数据元素:",n);
CreateList(L,n);
do
{
printf("n n");
menu();
printf("请输入你的选择:");
scanf("%d",&m);
switch(m)
{
case 1:
printf("现在链表的元素为:");
p = L->next;
while(p!=NULL)
{
printf("%d ",p->data);
p = p->next;
}
printf("n");
break;
case 2:
printf("依次输入插入位置和数据元素(空格隔开):");
scanf("%d %d",&i,&e);
ListInsert(L,i,e);
break;
case 3:
printf("输入需要删除的元素的位置:");
scanf("%d",&i);
ListDelete(L,i,e);
break;
case 4:
printf("输入需要取出的元素的位置:");
scanf("%d",&i);
GetElem(L,i,e);
break;
case 0:
printf("已结束程序!!!n");
break;
default:
printf("输入错误!!!n");
}
}
while(m!=0);
}

解决方案

Status InitList(LinkList &L)
//申请的空间在函数中,当函数结束是,你的分配空间也就销毁了。。全局变量 VS 局部变量!!

时间: 2024-08-17 14:14:56

c-刚学数据结构写了个链表,调试无报错,一运行就显示“main.exe停止运行”。的相关文章

C语言顺序表基本操作,刚学数据结构还不懂怎么操作?求助!!

问题描述 C语言顺序表基本操作,刚学数据结构还不懂怎么操作?求助!! 1.建立一个顺序表,要求从键盘输入10个整数,并将该顺序表的元素从屏幕显示出来. 2.用函数实现在顺序表中查找其中一个元素,如果找到,返回该元素在顺序表中的位置和该元素的值,否则提示无此元素. 3.用函数实现顺序表的插入和删除操作.由用户输入待插入元素及插入位置,将完成插入后的顺序表输出:由用户输入删除第几个元素,将完成删除后的顺序表输出. 解决方案 http://zhidao.baidu.com/link?url=n-XCi

c语言-为什么算法可以没有输入,可以举个具体的例子吗 急!!我刚学数据结构,好多都不理解,求大神支招!

问题描述 为什么算法可以没有输入,可以举个具体的例子吗 急!!我刚学数据结构,好多都不理解,求大神支招! 为什么算法可以没有输入,可以举个具体的例子吗 急!!我刚学数据结构,好多都不理解,求大神支招! 解决方案 不一定需要输入,第一你可以在程序之中就把初始值传入函数,或者是你写数据生成器也不用输入. 解决方案二: 不只是算法没有输入,,很多也不需要输入啊

c++-新手刚加入C++,拿着源码环境报错,求求大家

问题描述 新手刚加入C++,拿着源码环境报错,求求大家 报了一堆错误 winternl.h 这是包含文件啊系统的,怎么可能会报错啊,求求大家,这是什么错误,我装的VC6.0编译的 --------------------Configuration: Shell - Win32 Debug--------------------Compiling...BrowserWnd.cppc:program files (x86)microsoft visual studiovc98includewinte

c++-visual studio 2015 只有点调试才报错,写代码的时候不报错?

问题描述 visual studio 2015 只有点调试才报错,写代码的时候不报错? 我写C++.用2013时,写代码的时候出错了会立即得到提示,但现在用2015就不行了? 请问如何设置可使在写代码的时候得到出错的提示? 解决方案 应该是你安装设置的问题.另外第一次启动,需要扫描和缓存智能感知,你看下状态栏有没有提示. 解决方案二: 是不是你的intellisense有问题?把工程rebuild一下试试.还不行.可能你编译器安装有问题. 解决方案三: 是有报错提示的,不过报错有时候有延迟,有时

spring 写junit测试时使用aop报错

问题描述 spring 写junit测试时使用aop报错 当我在我的配置文件中加上如下配置会包下面的错误,我不加时就不会出错这是为什么 <aop:config> <aop:pointcut id="interceptorPointCuts" expression="execution(* cn.qtt.service.*.*(..)) " /> <aop:pointcut id="interceptorPointCutsNew

链表 递归-递归建立链表为什么会报错?

问题描述 递归建立链表为什么会报错? #include #include struct node { int num; struct node*next; }; void creatlist(struct node*p); void printlist(struct node*p); int main() { struct node*p; creatlist(p); printlist(p); return 0; } void creatlist(struct node*p) { p=(stru

为什么link中调用函数参数写少了也不会报错?难道参数写少了也可以调用么?

问题描述 为什么link中调用函数参数写少了也不会报错?难道参数写少了也可以调用么? 为什么link中调用函数参数写少了也不会报错?难道参数写少了也可以调用么? 解决方案 有默认参数这个东东,所以有可能存在参数写少了不会报错:但写多了,是一定会报错的.

小菜一步一步学数据结构之(四)单链表

上一篇博客学习了顺序表,最后也说明了顺序表属于静态存储,数据元素的个数不能自由的扩充.为了解决这个问题我们引入了链表 链表存储结构 结点在存储器中的位置是任意的,即逻辑上相邻的数据元素在物理上不一定相邻,因此线性表的链式表示又称为非顺序映像或链式映像. 各个结点有两个域组成: * 数据域:存储元素数值数据 * 指针域:存储直接后继结点的存储位置 名词解析 1. 结点:数据元素的存储映像.有数据域和指针域两部分组成. 2. 链表:n个结点由指针链组成一个链表.它是线性表的链式存储映像,称为线性表的

我按照书上写了一段代码为什么报错呢?如何解决?

问题描述 错误1程序"d:用户目录我的文档VisualStudio2013ProjectsConsoleApplication1ConsoleApplication1objDebugConsoleApplication1.exe"不包含适合于入口点的静态"Main"方法D:用户目录我的文档VisualStudio2013ProjectsConsoleApplication1ConsoleApplication1CSCConsoleApplication1 解决方案