标题:求大神来找错 此程序不能运行 (线性表顺序储存)
只看楼主
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
结帖率:83.33%
已结贴  问题点数:10 回复次数:3 
求大神来找错 此程序不能运行 (线性表顺序储存)
#include <stdio.h>
#define MAXSIZE 100
typedef int ElemType;
typedef struct
{
    ElemType elem[MAXSIZE];
    int last;
}SeqList;
int Locate(SeqList L,ElemType e);
int PriList(SeqList L);
int LnsList(SeqList *L,int i,ElemType e);
int main()
{
   
    SeqList L1;
    L1.elem[0]=5;
    L1.elem[1]=6;
    L1.elem[2]=9;
    L1.last=2;
    int i=2;
    ElemType j=6;
    L1=LnsList(&L1,i,j);
    PriList(L1);
    return 0;
}
int Locate(SeqList L,ElemType e)
{
    int i=0;
    while(i<=L.last&&L.elem[i]!=e)
           i++;
    if(i<=L.last)
           return (i+1);
    else
           return (-1);        
   
}
int PriList(SeqList L)
{
     int i;
    for(i=0;i<=L.last;i++)
           printf("%d",L.elem[i]);

}
SeqList LnsList(SeqList *L,int i,ElemType e)   
{
    int k;
    if(i<1&&i>L->last+2)
    {
           printf("输入错误");
           return(ERROR);//atantion
    }
    if(L->last=MAXSIZE-1)
    {
           printf("表已满");
           return(ERROR);
        }
     for(k=L->last;k>=i-1;k--)
           L->elem[k+1]=L->elem[k];
     L->elem[i-1]=e;      
     L->last++;
     return L;
                          
}
SeqList DelList(SeqList *L,int i,ElemType *e)
{
    int k;
    if(i<1&&i>L->last+1)
    {
           printf("删除位置错误");
           return(ERROR);
    }
    for(k=i-1;k<=L->last+1;k++)
           L->elem[k]=L->elem[k+1];
    *e=L->elem[i-1];
    return L;               
}

搜索更多相关主题的帖子: 线性表 int elem return printf 
2018-04-06 23:57
lanke711
Rank: 9Rank: 9Rank: 9
来 自:流浪在天国之路
等 级:蜘蛛侠
威 望:7
帖 子:317
专家分:1437
注 册:2015-7-16
得分:5 
以.c文件来编译。

#include <stdio.h>
#define MAXSIZE 100
typedef int ElemType;
typedef struct
{
    ElemType elem[MAXSIZE];
    int last;
}SeqList;
int Locate(SeqList L,ElemType e);
int PriList(SeqList L);
int LnsList(SeqList *L,int i,ElemType e);//声明类型为int,定义类型SeqList.声明和定义函数的类型就两种。。。
int main()
{

    SeqList L1;
    L1.elem[0]=5;
    L1.elem[1]=6;
    L1.elem[2]=9;
    L1.last=2;
    int i=2;    //虽然说在VS不会报错,但是在VC就开始报错了。因为不支持这样写。而且这样写也是一个坏习惯。声明定义应该写在函数开始的地方。
    ElemType j=6;    //同上
    L1=LnsList(&L1,i,j);
    PriList(L1);
    return 0;
}
int Locate(SeqList L,ElemType e)
{
    int i=0;
    while(i<=L.last&&L.elem[i]!=e)
           i++;
    if(i<=L.last)
           return (i+1);
    else
           return (-1);        
   
}
int PriList(SeqList L)//这个PriList函数是一个int类型,代码块没有返回值
{
     int i;
    for(i=0;i<=L.last;i++)
           printf("%d",L.elem[i]);
    //return 啥??没写
}
SeqList LnsList(SeqList *L,int i,ElemType e)   //此定义SeqList,上面的声明int
{
    int k;
    if(i<1&&i>L->last+2)
    {
           printf("输入错误");
          return(ERROR);//atantion ERROR没定义
    }
    if(L->last=MAXSIZE-1)
    {
           printf("表已满");
           return(ERROR);//ERROR没定义
        }
     for(k=L->last;k>=i-1;k--)
           L->elem[k+1]=L->elem[k];
     L->elem[i-1]=e;      
     L->last++;
     return L;//差点忘了。L是指针,函数类型SeqList不是指针,返回值类型不匹配
                          
}
SeqList DelList(SeqList *L,int i,ElemType *e)
{
    int k;
    if(i<1&&i>L->last+1)
    {
           printf("删除位置错误");
          return(ERROR);//ERROR没定义
    }
    for(k=i-1;k<=L->last+1;k++)
           L->elem[k]=L->elem[k+1];
    *e=L->elem[i-1];
    return L;//同上,返回值类型不匹配               
}

[此贴子已经被作者于2018-4-7 01:09编辑过]


普通人之所以普通,是因为他们普遍有一个通病,那就是认为自己永远普通。
千夫所指,我亦坚持。就算被所有人误解,我也照样守护这一切。
我们总是觉得,这些灵魂的表情,傲慢自大,目中无人,其实,真正目中无人的是我们。它们傲慢的不过是表情,而我们傲慢的却是行为!
记得,是为了忘记!
只要想着有那么一天,我就能忍受现在的每一天!
灾难并不可怕,可怕的是心中没有了希望。
你以为我在天堂,其实我正在路上。
当你觉得自己走不到终点的时候,请不要放弃。或许你的对手也是这种感觉。
2018-04-07 01:01
lanke711
Rank: 9Rank: 9Rank: 9
来 自:流浪在天国之路
等 级:蜘蛛侠
威 望:7
帖 子:317
专家分:1437
注 册:2015-7-16
得分:5 
cpp文件来编译。(为什么要用cpp文件来编译。我不希望有人跟我说Cpp兼容C。但是对于学习的C语言的同学,我希望,写C就C,写C++就CPP。等真正开发的时候,你想怎么混着写都行。)

#include <stdio.h>
#define MAXSIZE 100
typedef int ElemType;
typedef struct
{
    ElemType elem[MAXSIZE];
    int last;
}SeqList;
int Locate(SeqList L,ElemType e);
int PriList(SeqList L);
int LnsList(SeqList *L,int i,ElemType e);//声明的方法为int类型,定义的是SeqList类型。

int main()
{
   
    SeqList L1;
    L1.elem[0]=5;
    L1.elem[1]=6;
    L1.elem[2]=9;
    L1.last=2;
    int i=2;
    ElemType j=6;//C++允许这样写。

    L1=LnsList(&L1,i,j);
    PriList(L1);
    return 0;
}
int Locate(SeqList L,ElemType e)
{
    int i=0;
    while(i<=L.last&&L.elem[i]!=e)
           i++;
    if(i<=L.last)
           return (i+1);
    else
           return (-1);        
   
}
int PriList(SeqList L)
{
     int i;
    for(i=0;i<=L.last;i++)
           printf("%d",L.elem[i]);

}
SeqList LnsList(SeqList *L,int i,ElemType e)  //方法与上面声明的int类型不同
{
    int k;
    if(i<1&&i>L->last+2)
    {
           printf("输入错误");
          return(ERROR);//atantion  未定义ERROR
    }
    if(L->last=MAXSIZE-1)
    {
           printf("表已满");
           return(ERROR);//未定义ERROR
        }
     for(k=L->last;k>=i-1;k--)
           L->elem[k+1]=L->elem[k];
     L->elem[i-1]=e;      
     L->last++;
    return L;//返回值类型不匹配
                          
}
SeqList DelList(SeqList *L,int i,ElemType *e)
{
    int k;
    if(i<1&&i>L->last+1)
    {
           printf("删除位置错误");
           return(ERROR);//未定义的ERROR
    }
    for(k=i-1;k<=L->last+1;k++)
           L->elem[k]=L->elem[k+1];
    *e=L->elem[i-1];
    return L;   //返回值类型不匹配           
}

普通人之所以普通,是因为他们普遍有一个通病,那就是认为自己永远普通。
千夫所指,我亦坚持。就算被所有人误解,我也照样守护这一切。
我们总是觉得,这些灵魂的表情,傲慢自大,目中无人,其实,真正目中无人的是我们。它们傲慢的不过是表情,而我们傲慢的却是行为!
记得,是为了忘记!
只要想着有那么一天,我就能忍受现在的每一天!
灾难并不可怕,可怕的是心中没有了希望。
你以为我在天堂,其实我正在路上。
当你觉得自己走不到终点的时候,请不要放弃。或许你的对手也是这种感觉。
2018-04-07 01:25
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
得分:0 
回复 3楼 lanke711
首先非常感谢,我是一个新手不懂的有很多,我还是有很多问题

用cpp来编译

我的问题:
1.如果我把所有的函数返回值设置为'int'型,那么函数我直接在主函数中调用是不是就完成了操作
2.  int i=2;
    ElemType j=6;//C++允许这样写。
    这两条语句不就是单纯的定义语句吗,所以。。。

我尽我所学改了,如下(以下是我把函数的返回值都改为了int型)

#include <stdio.h>
#define MAXSIZE 100
#define ERROR 0;
#define OK 1;
typedef int ElemType;
typedef struct
{
    ElemType elem[MAXSIZE];
    int last;
}SeqList;
int Locate(SeqList L,ElemType e);
int PriList(SeqList L);
int LnsList(SeqList *L,int i,ElemType e);

int main()
{
   
    SeqList L1;
    L1.elem[0]=5;
    L1.elem[1]=6;
    L1.elem[2]=9;
    L1.last=2;
    int i=2;
    ElemType j=6;//C++允许这样写。
    LnsList(&L1,i,j);
    PriList(L1);
    return 0;
}
int Locate(SeqList L,ElemType e)
{
    int i=0;
    while(i<=L.last&&L.elem[i]!=e)
           i++;
    if(i<=L.last)
           return (i+1);
    else
           return (-1);        
   
}
int PriList(SeqList L)
{
     int i;
    for(i=0;i<=L.last;i++)
           printf("%d",L.elem[i]);
    return (OK);

}
int LnsList(SeqList *L,int i,ElemType e)  
{
    int k;
    if(i<1&&i>L->last+2)
    {
           printf("输入错误");
          return(ERROR);
    }
    if(L->last=MAXSIZE-1)
    {
           printf("表已满");
           return(ERROR);
        }
     for(k=L->last;k>=i-1;k--)
           L->elem[k+1]=L->elem[k];
     L->elem[i-1]=e;      
     L->last++;
     return (OK);
                          
}
int DelList(SeqList *L,int i,ElemType *e)//这里的删除函数的参数是指针 如果在主函数中定义了SeqList L1;是不是要传入L1的地址
{                                          //如果这里的返回值类型是SeqList那我怎么设置return(我怎样把指针类型转换为不是指针类型输出)
    int k;
    if(i<1&&i>L->last+1)
    {
           printf("删除位置错误");
           return(ERROR);
    }
    for(k=i-1;k<=L->last+1;k++)
           L->elem[k]=L->elem[k+1];
    *e=L->elem[i-1];
    return (OK);      
}

调试没有通过

看的我头都晕了
请指教


[此贴子已经被作者于2018-4-7 22:48编辑过]

2018-04-07 22:22



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-485807-1-1.html




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

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