C++,数据结构 请问,为什么编译没有出,但是运行就会出错呢?

#defineMaxSize50#include<iostream.h>#include<stdlib.h>#include<iomanip.h>typedefcharE... #define MaxSize 50
#include <iostream.h>
#include <stdlib.h>
#include <iomanip.h>
typedef char ElemType;
typedef struct
{ElemType data[MaxSize];
int length;
}SqList;
void BuildList(SqList *L,ElemType a[],int n)
{
int i=0;
L=new SqList;
for (;i<n;i++)
L->data[i]=a[i];
L->length=i;
}
//基本算法
void InitList(SqList *L)
{
L=new SqList;
L->length=0;
}
void DetroyList (SqList *&L)
{
free (L);
}
int EmptyList (SqList *L)
{
if(L->length) return 1;
return 0;
}
void DisplayList(SqList *L)
{
int i;
for (i=0;i<L->length;i++)
{
cout<<setw(8)<<L->data[i];
if (i%5==0) cout<<endl;
}
}
void GetElem(SqList *L,ElemType n)
{
if(n<=L->length)
{n--;
cout<<L->data[n]<<endl;}
else cout<<"超出范围!"<<endl;
}
void LocateElem(SqList *L,int n)
{
int i;
for (i=0;i<L->length;i++)
{
if (L->data[n]==n) break;
}
i++;
if (i<=L->length)
cout<<"该元素为:"<<i<<endl;
else cout<<"没有找到该元素!"<<endl;
}
void InsertElem (SqList *&L,int n,ElemType e)
{
if((n<=L->length+1)&&n<=MaxSize)
{
n--;
int i;
for (i=L->length;i!=n;i--)
L->data[i]=L->data[i-1];
L->data[i]=e;
}
else cout<<"操作失败,超出范围!"<<endl;
}
void DeleteElem (SqList *&L,int n)
{
if(n<=L->length)
{ int i;
for (i=0;i!=L->length-1;i++)
L->data[i]=L->data[i+1];
}
else cout<<"操作失败,超出范围!"<<endl;
}

void main()
{
SqList *L;
int n=5;
ElemType a[MaxSize]={'a','b','c','d','e'};
BuildList(L,a,n);
DisplayList (L);
cout<<"列表长度为:"<<L->length<<endl;
if (EmptyList (L)) cout<<"非空表"<<endl;
else cout<<"空表"<<endl;
GetElem(L,3);
LocateElem(L,'a');
InsertElem(L,4,'f');
DisplayList(L);
DeleteElem(L,3);
DisplayList(L);
}
展开
 我来答
xpston008
推荐于2016-10-28 · TA获得超过365个赞
知道小有建树答主
回答量:367
采纳率:100%
帮助的人:348万
展开全部
错误一堆啊。
void BuildList(SqList **L,ElemType a[],int n) //这样传递。SqList **L

#define MaxSize 50
#include <iostream>
#include <stdlib.h>
#include <iomanip>
using namespace std;
typedef char ElemType;
typedef struct
{ElemType data[MaxSize];
int length;
}SqList;
void BuildList(SqList **L,ElemType a[],int n)
{
int i=0;
*L=new SqList;
for (;i<n;i++)
(*L)->data[i]=a[i];
(*L)->length=i;
}
//基本算法
void InitList(SqList *L)
{
L=new SqList;
L->length=0;
}
void DetroyList (SqList *&L)
{
free (L);
}
int EmptyList (SqList *L)
{
if(L->length) return 1;
return 0;
}
void DisplayList(SqList *L)
{
int i;
for (i=0;i<L->length;i++)
{
cout<<setw(8)<<L->data[i];
if (i%5==0) cout<<endl;
}
}
void GetElem(SqList *L,ElemType n)
{
if(n<=L->length)
{n--;
cout<<L->data[n]<<endl;}
else cout<<"超出范围!"<<endl;
}
void LocateElem(SqList *L,int n)
{
int i;
for (i=0;i<L->length;i++)
{
if (L->data[n]==n) break;
}
i++;
if (i<=L->length)
cout<<"该元素为:"<<i<<endl;
else cout<<"没有找到该元素!"<<endl;
}
void InsertElem (SqList *&L,int n,ElemType e)
{
if((n<=L->length+1)&&n<=MaxSize)
{
n--;
int i;
for (i=L->length;i!=n;i--)
L->data[i]=L->data[i-1];
L->data[i]=e;
}
else cout<<"操作失败,超出范围!"<<endl;
}
void DeleteElem (SqList *&L,int n)
{
if(n<=L->length)
{ int i;
for (i=0;i!=L->length-1;i++)
L->data[i]=L->data[i+1];
}
else cout<<"操作失败,超出范围!"<<endl;
}

void main()
{
SqList *L=NULL;
int n=5;
ElemType a[MaxSize]={'a','b','c','d','e'};
BuildList(&L,a,n);
DisplayList (L);
cout<<"列表长度为:"<<L->length<<endl;
if (EmptyList (L)) cout<<"非空表"<<endl;
else cout<<"空表"<<endl;
GetElem(L,3);
LocateElem(L,'a');
InsertElem(L,4,'f');
DisplayList(L);
DeleteElem(L,3);
DisplayList(L);
}
追问
void BuildList(SqList **L,ElemType a[],int n) //这样传递。SqList **L

指向指针的指针?为什么要这样呢?
可以加QQ问你吗?
追答
理解值传递和地址传递。
33563743
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xu_weii
2013-03-16 · 超过24用户采纳过TA的回答
知道答主
回答量:57
采纳率:0%
帮助的人:56万
展开全部
void LocateElem(SqList *L,int n)
{
int i;
for (i=0;i<L->length;i++)
{
if (L->data[n]==n) break; //改为L->data[i]==n
}
i++;
if (i<=L->length)
cout<<"该元素为:"<<i<<endl;
else cout<<"没有找到该元素!"<<endl;
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sssoneshow
2013-03-16
知道答主
回答量:26
采纳率:33%
帮助的人:16.5万
展开全部
运行时出了什么错,有没有图片
来自:求助得到的回答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式