| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 806 人关注过本帖
标题:线性表的初始化,查找,插入,删除的程序错在哪里???还请指教。调试了几 ...
只看楼主 加入收藏
zyfmoto
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2014-9-14
结帖率:100%
收藏
 问题点数:0 回复次数:4 
线性表的初始化,查找,插入,删除的程序错在哪里???还请指教。调试了几次,改了几次还是通不过
# include<stdio.h>
# include<stdlib.h>
# define LIST_INIT_SIZE 100
# define LISTINCREMENT 10
# define OVERFLOW -2
# define OK 1
# define ERROR 0
typedef int ElemType;

  typedef struct Sqlist
{
  ElemType *elem;
      int length;
      int listsize;
}Sqlist;

void main()
{
Sqlist *L,S;
    L=&S;
    int i,j,e,n;
    int InitList_Sq(Sqlist *L,int n);
    int LocateELem_Sq(Sqlist *L,int i,ElemType e);
    int ListInsert_Sq(Sqlist *L,int i,ElemType e);
    int ListDelete_Sq(Sqlist *L,int i);
    int PutList(Sqlist *L);
printf("输入表的长度:\n");
scanf("%d",&n);
    InitList_Sq(L,n);
    PutList(L);
    printf("输入查找的位置:\n");
    scanf("%d",&i);
    LocateElem_Sq(L,i);
    PutList(L);
    printf("输入插入的位置:\n");
    scanf("%d",&i);
    printf("输入插入的值:\n");
    scanf("%d",&e);
    ListInsert_Sq(L,i,e);
    PutList(L);
    printf("输入删除的位置:\n");
    scanf("%d",&j);
    ListDelete_Sq(L,j);
    PutList(L);
}

int InitList_Sq(Sqlist *L,int n)
{
    int i;
    ElemType *newbase;
    L->elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));
    if(!L->elem)
exit(OVERFLOW);
    L->length=0;
    L->listsize=LIST_INIT_SIZE;
   printf("请输入表中的数据:\n");
   for(i=0;i<n;i++)
   {
   scanf("%d",&L->elem[i]);
       ++L->length;
       if(L->length>L->listsize)
   {
   newbase=(ElemType*)realloc(L->elem,(L->listsize+LISTINCREMENT)*sizeof(ElemType));
           if(!newbase)
   exit(OVERFLOW);
           L->elem=newbase;
           L->listsize+=LISTINCREMENT;
   }
   }
    return OK;
}

int ListInsert_Sq(Sqlist *L,int i,ElemType e)
{
 ElemType *p,*q,*newbase;
 if(i<1||i>L->length+1)
 return ERROR;
 if(L->length>=L->listsize)
 {
 newbase=(ElemType*)realloc(L->elem,(L->listsize+LISTINCREMENT)*sizeof(ElemType));
     if(!newbase)
     exit(OVERFLOW);
     L->elem=newbase;
     L->listsize+=LISTINCREMENT;
 }
 q=&L->elem[i-1];
 for(p=&L->elem[L->length-1];p>=q;--p)
 *(p+1)=*p;
 *q=e;
 ++L->length;
 return OK;
}
int LocateELem_Sq(SqList *L,ElemType e){
    for(i=0;i<L.length;i++)
        if(L.elem[i]==e) return i+1;
        printf("查找的元素为:\n%d\n",e);
        return 0;
}
int ListDelete_Sq(Sqlist *L,int i)
{
 ElemType *p,*q;
 int e;
 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;
 printf("删除的元素为:\n%d\n",e);
 return 0;
}

int PutList(Sqlist *L)
{
 int *p,*q;
 p=L->elem;
 q=L->elem+(L->length-1);
 printf("线性表中元素为:\n");
 for(p=L->elem;p<=q;++p)
 {
 printf("%d  ",*p);
 }
 printf("\n表长为:%d  \n",L->length);
 return OK;
}
搜索更多相关主题的帖子: 线性表 include 
2014-09-22 17:04
dcl2014
Rank: 4
等 级:业余侠客
威 望:1
帖 子:58
专家分:273
注 册:2014-9-20
收藏
得分:0 
//这是修改之后的 可以运行
# include<stdio.h>
# include<stdlib.h>
# define LIST_INIT_SIZE 100
# define LISTINCREMENT 10
# define OVERFLOW -2
# define OK 1
# define ERROR 0
typedef int ElemType;

  typedef struct Sqlist
{
  ElemType *elem;
      int length;
      int listsize;
}Sqlist;

void main()
{
    Sqlist *L,S;
    L=&S;
    int i,j,e,n,tp=0;
    int InitList_Sq(Sqlist *L,int n);
    int LocateElem_Sq(Sqlist *L,int *p,ElemType e);
    int ListInsert_Sq(Sqlist *L,int i,ElemType e);
    int ListDelete_Sq(Sqlist *L,int i);
    int PutList(Sqlist *L);
    printf("输入表的长度:\n");
    scanf("%d",&n);
    InitList_Sq(L,n);
    PutList(L);
    printf("输入查找的值:\n");
    scanf("%d",&e);
    LocateElem_Sq(L,&tp,e);
    PutList(L);
    printf("输入插入的位置:\n");
    scanf("%d",&i);
    printf("输入插入的值:\n");
    scanf("%d",&e);
    ListInsert_Sq(L,i,e);
    PutList(L);
    printf("输入删除的位置:\n");
    scanf("%d",&j);
    ListDelete_Sq(L,j);
    PutList(L);
}

int InitList_Sq(Sqlist *L,int n)
{
    int i;
    ElemType *newbase;
    L->elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));
    if(!L->elem)
exit(OVERFLOW);
    L->length=0;
    L->listsize=LIST_INIT_SIZE;
   printf("请输入表中的数据:\n");
   for(i=0;i<n;i++)
   {
   scanf("%d",&L->elem[i]);
       ++L->length;
       if(L->length>L->listsize)
   {
   newbase=(ElemType*)realloc(L->elem,(L->listsize+LISTINCREMENT)*sizeof(ElemType));
           if(!newbase)
   exit(OVERFLOW);
           L->elem=newbase;
           L->listsize+=LISTINCREMENT;
   }
   }
    return OK;
}

int ListInsert_Sq(Sqlist *L,int i,ElemType e)
{
ElemType *p,*q,*newbase;
if(i<1||i>L->length+1)
return ERROR;
if(L->length>=L->listsize)
{
newbase=(ElemType*)realloc(L->elem,(L->listsize+LISTINCREMENT)*sizeof(ElemType));
     if(!newbase)
     exit(OVERFLOW);
     L->elem=newbase;
     L->listsize+=LISTINCREMENT;
}
q=&L->elem[i-1];
for(p=&L->elem[L->length-1];p>=q;--p)
*(p+1)=*p;
*q=e;
++L->length;
return OK;
}

int LocateElem_Sq(Sqlist *L,int *p,ElemType e)
{
    for(int i=0;i<(*L).length;i++)
        if((*L).elem[i]==e)
        {    *p=i+1;
            break;
        }
        printf("查找的元素e=%d的位置为:\n%d\n",e,*p);
        return 0;
}
int ListDelete_Sq(Sqlist *L,int i)
{
ElemType *p,*q;
int e;
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;
printf("删除的元素为:\n%d\n",e);
return 0;
}

int PutList(Sqlist *L)
{
int *p,*q;
p=L->elem;
q=L->elem+(L->length-1);
printf("线性表中元素为:\n");
for(p=L->elem;p<=q;++p)
{
printf("%d  ",*p);
}
printf("\n表长为:%d  \n",L->length);
return OK;
}
2014-09-23 20:34
zyfmoto
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2014-9-14
收藏
得分:0 
回复 2 楼 dcl2014
谢谢你帮忙改了,可以运行,编译通过了
2014-09-27 21:32
夏午
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2014-10-6
收藏
得分:0 
这个一般用C语言编写还是其他的,刚刚学,是新手
2014-10-06 12:40
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:0 
赞一个

Maybe
2014-10-06 13:54
快速回复:线性表的初始化,查找,插入,删除的程序错在哪里???还请指教。调试 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.030970 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved