Tsz Foon 2022-03-16 10:19 采纳率: 91.7%
浏览 24
已结题

请问这个位置无效是怎么回事呢

问题遇到的现象和发生背景
问题相关代码,请勿粘贴截图
运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果

应该就是Insertlist这一步的问题,但是if里面的内容好像也没错啊

#include<stdio.h>
#include<cstring>
#include<iostream>
#define MAX_SIZE 1000
#define Elemtype int
#define Status int

/******************************************基本操作函数*****************************************************************************/
/*构建一个顺序表类型*/
typedef struct
{
    Elemtype data[MAX_SIZE];
    int length;
}Sqlist;

/*初始化顺序表函数,构造一个空的顺序表*/
Status Intlist(Sqlist& L)
{
    memset(L.data, 0, sizeof(L));//可以用"0"来初始化任何类型数组!比如 memset(arr,0,sizeof(arr));//arr可以是char或int等类型数组!
    L.length = 0;
    return 0;
}

/*创建顺序表函数,初始化前n个数字*/
bool Creatlist(Sqlist& L, int n)
{
    if (n<0 || n>MAX_SIZE)
    {
        return false;
    }
    for (int i = 0; i < n; i++)
    {
        scanf("%d", &L.data[i]);
        L.length++;//这步没问题 
    }
    return true;
}

/*插入函数,在位置i上插入函数后,i后位置依次向后移动一位*/
bool Insertlist(Sqlist& L, int i, Elemtype e)//Insertlist是在Insert函数中调用的
{
    if (i<1 || i>L.length + 1)
    {
        printf("位置无效\n");
        return false;
    }
    if (L.length > MAX_SIZE)
    {
        printf("当前存储空间已满\n");
        return 0;
    }
    for (int j = L.length; j >= i; j--)
    {
        L.data[j] = L.data[j - 1];
    }
    L.data[i - 1] = e;
    L.length++;
    return true;
}

/******************************************************功能函数****************************************************************/

//输出功能函数
void Printlist(Sqlist L)
{
    printf("当前顺序表所有元素为");
    for(int i=0;i<L.length;i++)
    {
        printf("%d ",L.data[i]);
    }
    printf("\n");
} 

//创建顺序表函数
void creat(Sqlist L)
{
    int n;bool flag;
    L.length=0;
    printf("请输入要创建的顺序表长度(n>0)\n");
    scanf("%d",&n);
    printf("请输入n个数,用空格隔开\n");
    flag=Creatlist(L,n);
        printf("L.length=%d",L.length);
    if(flag==true)
    {
        printf("创建成功\n");
        Printlist(L);
    }
    else
    {
        printf("输入长度非法\n");
    }
    
 } 
 


/*插入功能函数,调用Insertlist函数来实现*/
void Insert(Sqlist& L)
{
    int place; Elemtype e; bool flag;
    printf("请选择要插入的位置以及元素,从第一位开始\n");
    scanf("%d%d", &place, &e);
    printf("i=%d",place);
    flag = Insertlist(L, place, e);                       //Insert函数(L是线性表,插入位置,插入数字) 
    if (flag == 1)
    {
        printf("插入成功\n");
        for (int i = 0; i < L.length; i++)
        {
            printf("%d  ", L.data[i]);
        }
    }

}

int main()
{
    Sqlist L;
    Intlist(L);
    creat(L);
    Insert(L);
    
    return 0;
}




img

  • 写回答

3条回答 默认 最新

  • 不知怎么说 2022-03-16 10:31
    关注

    你的create函数参数用的是值传递,会重新创建对象,跟你在main函数创的对象就没关系了,所以你的L还是没有数据,是空的,在Insertlist的时候就会直接return

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月24日
  • 已采纳回答 3月16日
  • 创建了问题 3月16日

悬赏问题

  • ¥15 有偿求答 无导出权限怎么快速导出企业微信微文档
  • ¥15 求解答,怎么数码管中这么加入闹钟或者传感器,这应该怎么加入相应的代码
  • ¥15 scottplot5
  • ¥30 想问问这个建模怎么编程没有思路
  • ¥15 关于imageENview(ImageEN)中新建图层并根据鼠标位置添加图标
  • ¥100 用两台电脑局域联网进行MT5的EA参数优化,但是连接不上,日志提示:
  • ¥15 FastAPI报错: AsyncSession不是有效Pydantic类型
  • ¥50 这Mac系统提示虚拟内存不足,怎么解决
  • ¥15 Rs232电路无法收发数据,求帮助
  • ¥15 百度cookie扫码登录器