请大家帮忙调试一下

ouyangqin 2008-04-27 12:31:33

#include<stdio.h>
#define INITSIZE 100
#define LISTINCREAMENT 10
#define OK 1
#define ERROR 0
#define OVERFLOW -1
typedef struct{
int *elem;
int length;
int listsize;
}sqlist;

int initlist(sqlist &L)
{
int i,*q;
L.elem=(int*)malloc(INITSIZE*sizeof(int));
if(!L.elem)exit(OVERFLOW);
L.length=0;
L.listsize=INITSIZE;
q=&(L.elem[i-1]);
for(i=1;i<=L.listsize;i++)
{
int e;
scanf("%d",&e);
*q=e;
++L.length;
}
}

int listinsert(sqlist &L)
int i,e,*P,*q;
if(i<1||i>L.length+1)
return ERROR;
if(L.length>=L.listsize){
newbase=(int*)realloc(L.elem,(L.listsize+LISTINCREAMENT)*sizeof(int));
if(!newbase)exit(OVERFLOW);
L.elem=newbase;
L.listsize+=LISTINCREAMENT;
}
q=&(L.elem[i-1]);
for(p=&(L.elem[L.length-1];p>=q;--p)
*(p+1)=*p;
*q=e;
++L.length;
scanf("%d%d",i,e);
return OK;
}

int listdelete(sqlist&L){
int i,e,*P,*q;
if((i<1)||(i>L.length))
return ERROR;
p=&(L.elem[i-1]);
e=*p;
q=L.elem+L.length-1;
for(++p;p<q;p++)
*(p-1)=*p;
--L.length;
return OK;
}

void main()
{
sqlist L;
initlist(sqlist &L);
listinsert(sqlist &L);
listdelete(sqlist &L);
}
运行环境wintc
...全文
94 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
jxfengzi 2008-04-27
  • 打赏
  • 举报
回复
代码是抄来的吧?

真的想学好C的话,建议这样做:

先自己实现一个链表,调试成功后,再看别人做的。
有比较,有思考,才能提高。
Acyk 2008-04-27
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 jieao111 的回复:]
晚上脑子不好使~~
[/Quote]

……,汗
jieao111 2008-04-27
  • 打赏
  • 举报
回复
void main() 
{
sqlist L;
initlist(L);
listinsert(L);
listdelete(L);
}


晚上脑子不好使~~
jieao111 2008-04-27
  • 打赏
  • 举报
回复
 void main() 
{
sqlist L;
initlist(sqlist L);
listinsert(sqlist L);
listdelete(sqlist L);
}


你不会函数调用吗

69,373

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧