c语言数据结构线性表插入和删除实现代码错误在哪

#include<stdio.h>#include<stdlib.h>#include<malloc.h>#defineMAXSIZE100;#defineTURE1#d... #include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#define MAXSIZE 100;
#define TURE 1
#define ERROR 0
typedef Elmetype int
typedef struct{
Elmetype *elme;
int length;
}Sqlist;
int initlist(Sqlist *L){
L->elme=(Elmetype *)malloc(MAXSIZE*sizeof(Elmetype));
if(!L->elme) return ERROR;
L->length=0;
return TURE;
}
int insertlist(Sqlist *L,int i,Elmetype e){
if(i<1||i>L->length+1) return ERROR;
if(L->elme+L->length-1>=L->MAXSIZE) return ERROR;
Elmetype *P,*q;
q=L->elme+i-1;
p=L->elme+L->length-1;
for(;p>=q;p--){
*(p+1)=*P;
}
*q=e;
++L->length;
return TURE;
}
int deletelist(Sqlist *L,int i){
if(i<1||i>L->length+1) return ERROR;
if(L->length==0) return ERROR;
Elmetype *P,*q;
q=L->elme+i-1;
p=L->elme+L->length-1;
for(;q<=p;q++){
*q=*(q+1);
}
q=L->elme+i-1;
free(q);
--L->length;
}
void displaylist(Sqlist L){
int i;
for(i=0;i<=MAXSIZE;i++){
printf("%d\t",L->elme[i]);
}
}
int main(void){
Sqlist *L;
L=(Elmetype *)malloc(MAXSIZE*sizeof(Elmetype));
Elmetype e;
int i;
initlist(L);
printf("Enter i:");
scanf("%d",&i);
while(i<1000){
printf("Enter e:");
scanf("%d",&e);
insertlist(L,i,e);
printf("Enter i:");
scanf("%d",&i);
}
displaylist(L);
printf("Enter i:");
scanf("%d",&i);
while(i<1000){
deletelist(L,i);
printf("Enter i:");
scanf("%d",&i);
}
displaylist(L);
return 0;
}错误在哪
展开
 我来答
xoaxa
2014-03-30 · TA获得超过8611个赞
知道大有可为答主
回答量:6415
采纳率:72%
帮助的人:3503万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define MAXSIZE 100
#define TRUE 1
#define ERROR 0

typedef int ElemType;

typedef struct list {
ElemType *elme;
int length;
}Sqlist;

int initlist(Sqlist *L) {
L->elme = (ElemType *)malloc(MAXSIZE * sizeof ElemType);
if(L->elme == NULL) return ERROR;
L->length = 0;
return TRUE;
}

int insertlist(Sqlist *L,int pos,ElemType e) {
int i;
if(L->length == 0) { // 第一元素无条件插入
L->elme[0] = e;
L->length = 1;
return TRUE;
}
if(L->length >= MAXSIZE) {
printf("表满。length = %d。\n",L->length);
return ERROR;
}
if(pos < 1 || pos > L->length) {
printf("插入位置不合理。\n");
printf("表长:%d,位置:%d\n",L->length,pos);
printf("元素%d未能插入。\n",e);
return ERROR;
}
for(i = L->length; i > pos - 1; --i)
L->elme[i] = L->elme[i - 1];
L->elme[pos - 1] = e;
++L->length;
return TRUE;
}

int deletelist(Sqlist *L,int pos) {
int i;
if(pos < 1 || pos > L->length) {
printf("删除位置不合理。\n");
printf("表长:%d,位置:%d\n",L->length,pos);
printf("第%d个元素未能删除。\n",pos);
return ERROR;
}
for(i = pos - 1; i < L->length - 1; ++i)
L->elme[i] = L->elme[i + 1];
--L->length;
return TRUE;
}

void displaylist(Sqlist *L) {
int i;
for(i = 0;i < L->length; i++)
printf("%d ",L->elme[i]);
printf("\n");
}

int main(void){
Sqlist *L = (Sqlist *)malloc(sizeof(Sqlist));
int i,n,pos,res;
initlist(L);
printf("Enter n:");
scanf("%d",&n);
srand((unsigned)time(NULL));
for(i = 0; i < n; ++i) {
res = insertlist(L,i,rand() % 100);
if(res == ERROR) --i;
}
displaylist(L);
printf("Enter pos:");
scanf("%d",&pos);
deletelist(L,pos);
displaylist(L);
return 0;
}
追问
请问你用的这个编程软件在哪下的能发个给我?
追答
我用的是VC++ 6.0,你应该有的。
Benbamboo
2014-03-30 · TA获得超过132个赞
知道小有建树答主
回答量:572
采纳率:0%
帮助的人:184万
展开全部
typedef Elmetype int,是typedef int Elmetype ;
追问
还有其他错误运行不了啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式