| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 684 人关注过本帖
标题:调试程序遇到错误,不解,求教!
只看楼主 加入收藏
☆Jony☆
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-2-22
收藏
 问题点数:0 回复次数:3 
调试程序遇到错误,不解,求教!
我的运行环境是C与C++程序设计学习与实验系统,程序如下:错误处已经用红色标注!
#include "stdio.h"

#define MAXSIZE
typedef struct
{
    int data[MAXSIZE];
    int Length;
}SqList;

void InitList(SqList *L)
{
    L->Length=0;
}

int GetLength(SqList L)
{
    return L.Length;
}

int GetElem(SqList L,int i,int *e)
{
    if(i<1||i>L.Length)
    return 0;
    else
    {
        *e=L.data[i-1];
        return 1;
    }
}

int Locate(SqList L,int x)
{
    int i=0;
    while(L.data[i]!=x)
    i++;
    if(i>L.Length)
    return(0);
    else
    return(i+1);
}

int insElem(SqList *L,int x,int i)
{
    int j;
    if(i<1||i>L->Length+1)
    L->data[j]=L->data[j-1];
    L->data[i-1]=x;
    L->Length++;
    return 1;
}

int DelElem(SqList L,int i)
{
    int j;
    if(i<1||i>L.Length)
    return 0;
    for(j=i;j<L.Length;j++)
    L.data[j-1]=L.data[j];
    L.Length--;
    return 1;
}

void DispList(SqList L)
{
    int i;
    for(i=1;i<=L.Length;i++)
    printf("%c",L.data[i-1]);
    printf("\n");
}


void main()
{
    int i;
    int *e;
    SqList L;
    InitList(&L);
    InsElem(L,'a',1);
    InsElem(L,'c',2);
    InsElem(L,'a',3);
    InsElem(L,'e',4);
    InsElem(L,'d',5);
    InsElem(L,'b',6);
    printf("线性表");DispList(L);
    printf("长度:%d\n",GetLength(L));
    i=3;GetElem(L,i,e);
    printf("第%d个元素\n",i,e);
    *e='a';
    printf("元素%c是第%d个元素\n",e,Locate(L,*e));
    i=4;printf("删除第%d个元素\n",i);
    DelElem(L,i);
    printf("线性表:");DispList(L);   
}
错误提示见图片
不知道是什么原因,请指教!

未命名.jpg (11.76 KB)
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: int SqList Length 
2008-05-07 09:29
mqh21364
Rank: 1
等 级:新手上路
帖 子:642
专家分:0
注 册:2008-2-28
收藏
得分:0 
#define MAXSIZE
多少????????MAXSIZE代表多少呢????
int insElem(SqList *L,int x,int i)
InitList(&L);
    InsElem(L,'a',1);
    InsElem(L,'c',2);
    InsElem(L,'a',3);
    InsElem(L,'e',4);
    InsElem(L,'d',5);
    InsElem(L,'b',6);

你看看你的调用和定义一致不????

前不见古人,后不见来者。念天地之悠悠,独怆然而涕下。
2008-05-07 09:55
卷入内核
Rank: 1
等 级:新手上路
帖 子:30
专家分:0
注 册:2007-7-2
收藏
得分:0 
回复
首先你的预定义语句'#define MAXSIZE'  把MAXSIZE定为空,这样你的结构数组变成   int data[]   空声明,所以报第一个错

第二个错就是你的  函数:InsElem(L,'a',1);明显在上面写成了
int insElem(SqList *L,int x,int i)

大小写搞错,请注意
2008-05-07 10:00
☆Jony☆
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-2-22
收藏
得分:0 
麻烦两位了!确实是自己疏忽了!以后还得更加仔细些呀!
Thanks!
以下是改正的程序和答案,供大家参考!
/* Note:Your choice is C IDE */
#include "stdio.h"

#define MAXSIZE 10
typedef struct
{
    int data[MAXSIZE];
    int Length;
}SqList;

void InitList(SqList *L)
{
    L->Length=0;
}

int GetLength(SqList L)
{
    return L.Length;
}

int GetElem(SqList L,int i,int *e)
{
    if(i<1||i>L.Length)
    return 0;
    else
    {
        *e=L.data[i-1];
        return 1;
    }
}

int Locate(SqList L,int x)
{
    int i=0;
    while(L.data[i]!=x)
    i++;
    if(i>L.Length)
    return(0);
    else
    return(i+1);
}

int InsElem(SqList *L,int x,int i)
{
    int j;
    if(i<1||i>L->Length+1)
    L->data[j]=L->data[j-1];
    L->data[i-1]=x;
    L->Length++;
    return 1;
}

int DelElem(SqList *L,int i)
{
    int j;
    if(i<1||i>L->Length)
    return 0;
    for(j=i;j<L->Length;j++)
    L->data[j-1]=L->data[j];
    L->Length--;
    return 1;
}

void DispList(SqList L)
{
    int i;
    for(i=1;i<=L.Length;i++)
    printf("%c",L.data[i-1]);
    printf("\n");
}


void main()
{
    int i;
    int e;
    SqList L;
    InitList(&L);
    InsElem(&L,'a',1);
    InsElem(&L,'c',2);
    InsElem(&L,'a',3);
    InsElem(&L,'e',4);
    InsElem(&L,'d',5);
    InsElem(&L,'b',6);
    printf("线性表");DispList(L);
    printf("长度:%d\n",GetLength(L));
    i=3;GetElem(L,i,&e);
    printf("第%d个元素:%c\n",i,e);
    e='a';
    printf("元素%c是第%d个元素\n",e,Locate(L,e));
    i=4;printf("删除第%d个元素\n",i);
    DelElem(&L,i);
    printf("线性表:");DispList(L);   
}

未命名.jpg (9.57 KB)
图片附件: 游客没有浏览图片的权限,请 登录注册

☆滴水穿石☆水滴石穿☆
QQ:920633639
2008-05-07 15:07
快速回复:调试程序遇到错误,不解,求教!
数据加载中...
 
   



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

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