蓝星461 2022-10-16 02:05 采纳率: 80%
浏览 51
已结题

C语言数据结构顺序表

C语言数据结构
用代码块功能插入代码,请勿粘贴截图
#include <stdio.h>
#define ERROR 0 
#define OK
#define MAXSIZE 100
typedef char ElemType;
typedef struct
{
    ElemType date[MAXSIZE];
    int length;
 } SeqList;
 int InitList_Sq(SeqList *&L){
     L=new SeqList;
     if(!L)
     return ERROR;
     L->length=0;
     return OK;
 }
 void DestroyList_Sq(SeqList*&L)
 {
     delete L;
     L=NULL;
 }
 void ClearList_Sq(SeqList*&L)
 {
     L->Length;
 }
 int ListEmpty_Sq(SeqList*L)
 {
     return (L->length);
 }
 bool ListEmpty_Sq(SeqList*L)
 {
     if(L->length==0)
     return true ;
     else
         return false;
 }
 int GetElem_Sq(SeqList*L,int i,ElemType&e)
 {
     if(i<1||i>L->length)
             return RERRO;
             e=L->data[i-1];
         return OK;
 }
 int LocateElem_Sq(SeqList*L,ElemType e)
 {
     for(int i=1;i<L->length+1;i++)
        if (L->data[i-1]==e)
        return ERROR;
 }
 int ListInsert_Sq(SeqList*&L,int,ElemType&e)
 {
     if(L->length==MAXSIZE)
         return ERROR;
    if(i<1||i>L->length+1)
        return ERROR;
    for(int j=L->length-1;j>=i;j--)
       L->date[j+1]=L->data[j];
       L->date[i-1]=e;
       L->length++;
       return OK;
 }
 int ListDelete_Sq(SeqList*&L,int i,ElemType&e)
 {
     if(ListEmpty_Sq(L))
        return ERROR;
     if(i<1||i>L->length)
        return ERROR;
     e=L->dare[i-1];
     for(int j=i;j<L->length;j++)
     L->dare[j-1]=L->data[j];
     L->length--;
     return OK;
 }
 void DispList_Sq(SeqList*L)
 {
     int i;
     printf("顺序表:");
     if (ListEmpty_Sq(L)) {
         printf("表空!\n");
         return;
     }
     for(i=0;i<L->length;i++)
     printf("%c ",L->data[i]);
     printf("\n");
 }
 void showmenu()
 {
     printf("\n\n\n");
     printf("    --线性表顺序存储基本运算演示--   \n"); 
     printf("****************************************"); 
     printf("*    1------顺序表的初始化            *"); 
     printf("*    2------顺序表的初始化            *"); 
     printf("*    3------顺序表的初始化            *"); 
     printf("*    4------顺序表的初始化            *"); 
     printf("*    5------顺序表的初始化            *"); 
     printf("*    6------顺序表的初始化            *"); 
     printf("*    7------顺序表的初始化            *"); 
     printf("*    8------顺序表的初始化            *"); 
     printf("*    9------顺序表的初始化            *"); 
     printf("*                                      *"); 
     printf("*    0------退出            *"); 
     printf("****************************************"); 
     printf("请选择菜单号(0--9):"); 
 }
 void List_Sq()
 {
     char choice='N';
     ElemType item;
     int position;
 
 SeqList*L;
 int fiag=0;
 while(choice!=0)
 {
     shoemenu();
     _flushall();
     scanf("%c",&choice);
     switch(choice)
     {
         case'1':
             printf("初始化顺序表操作\n");
             if(InitList_Sq(L))
             {
                 printf("初始化成功!\n");
                 flag=1;
             }
             else
                printf("初始化失败\n");
                break;
        case'2':
            if(flag)
            {
                DestroyList_Sq(L);
                flag=0;
                printf("顺序表删除成功!\n");
            }
            else
            {
                printf("顺序表不存在,操作失败!\n");
            }
        case'3':
            if(flag)
            {
                ClearList_Sq(L);
                Printf("顺序表清空成功!\n");
                DispList_Sq(L);
            }
            else
            {
                printf("顺序表不存在,操作失败!\n");
            }
            break;
            case'4':
                if(flag)
                {
                printf("顺序表元素个数为%d\n",Listlength_Sq(L));
                DispList_Sq(L);    
                }
                else{
                    printf("顺序表不存在,操作失败!\n")
                }
            case'5':
                if(flag)
                {
                    printf("请输入元素的位序号:");
                     scanf("%d",Position);
                     if(GetElem_Sq(L,Position,item)==OK)
                     {
                         printf("第%d个元素为:%c\n",Position,item);
                     }
                }
                else{
                    printf("顺序表不存在,操作失败!\n")
                }
            case'6':
                if(flag)
                {
                    printf("请输入元素表的位序符号:");
                    scanf("%d",&Position);
                    if(GetElem_Sq(L,Position,item)==OK)
                    {
                        printf("第%d个元素为:%c\n",Postion,item);
                    }
                else{
                    printf("输入的位序号错误!\n");
                }
                DispList_Sq(L);
                }
                else{
                    printf("顺序表不存在,操作失败!\n")
                }
                break;
            case'7':
                if(flag)
                {
                    printf("请输入元素的值:")
                    _flushall();
                    scanf("%c",&item);
                    Position=LocateElem_Sq(L,item);
                    if(Position){
                        printf("该元素找到,位序是%d。\n",Position);
                    } 
                    else{
                        printf("该元素没找到!\n");
                    }
                    DispList_Sq(L);
                }
                else{
                    printf("顺序表不存在,操作失败!\n");
                }
            case'8':
                if(flag)
                {
                    printf("请输入元素的值:")
                    _flushall();
                    scanf("%c",&item);
                    printf("请输入要插入元素的位置序号:");
                    scanf("%d",&Position);
                    if(ListInsert_Sq(L,Position,item)==OK)
                    printf("该元素插入成功!\n");
                    else
                    printf("输入的位序号错误!\n");
                    DispList_Sq(L);
                }
                else{
                    printf("顺序表不存在,操作失败!\n")
                }
                break;
            case'9':
                if(flag)
                {
                    printf("请输入要删除元素的位置序号:");
                    scanf("%d",&Position);
                    if(ListDelete_Sq(L,Position,item)){
                        printf("删除的元素为%c\n",item);
                    } else{
                        printf("输入的位序号错误!\n");
                    }
                    DispList_Sq(L);
                }
                else{
                    printf("顺序表不存在,操作失败!\n")
                }
            case'0':    
            printf("\n\t 程序结束!\n");
            DestroyList_Sq(L);
            break;
            
            default:
                printf("\n\t 选择错误,请重新输入!\n");
                break;
     }
 }
}
int main()
{
    List_Sq();
    return 0;
}

int InitList_Sq(SeqList *&L)这里为什么会报错,该怎末改,

img

展开全部

  • 写回答

3条回答 默认 最新

  • 浪客 2022-10-16 02:21
    关注

    int InitList_Sq(SeqList *&L) &是引用,c没有引用,引用是C++的东西
    改用 int InitList_Sq(SeqList **L)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    蓝星461 2022-10-18 02:48

    这个是用c语言来写的,为什么非要c++才能编译

    回复
    浪客 回复 蓝星461 2022-10-18 03:21

    你用了引用,引用是C++的东西,c编译器编译不过去的。

    回复
查看更多回答(2条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 10月25日
  • 已采纳回答 10月18日
  • 创建了问题 10月16日

悬赏问题

  • ¥15 IBMP550小型机使用串口登录操作系统
  • ¥15 关于#python#的问题:现已知七自由度机器人的DH参数,利用DH参数求解机器人的逆运动学解目前使用的PSO算法
  • ¥15 发那科机器人与设备通讯配置
  • ¥15 Linux环境下openssl报错
  • ¥15 我在使用VS编译并执行之后,但是exe程序会报“无法定位程序输入点_kmpc_end_masked于动态链接库exe上“,请问这个问题有什么解决办法吗
  • ¥15 el-select光标位置问题
  • ¥15 单片机 TC277 PWM
  • ¥15 在更新角色衣服索引后,Sprite 并未正确显示更新的效果该如何去解决orz(标签-c#)
  • ¥15 VAE代码如何画混淆矩阵
  • ¥15 求遗传算法GAMS代码
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部