王道c语言督学营课时10作业

该代码示例展示了如何在C++中初始化一个顺序表,插入元素到指定位置,删除指定位置的元素,并打印顺序表。程序首先创建并初始化一个包含1,2,3的顺序表,然后插入元素6到第二个位置,接着删除第一个位置的元素,如果输入位置不合法则输出false。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>
#define MaxSize 4
//初始化顺序表(顺序表中元素为整型),里边的元素是1,2,3,
//然后通过scanf读取一个元素(假如插入的是6),插入到第2个位置,
//打印输出顺序表,每个元素占3个空格,格式为1  6  2  3,
//然后scanf读取一个整型数,是删除的位置(假如输入为1),然后输出顺序表  6  2  3,
//假如输入的位置不合法,输出false字符串。
//提醒,Language一定要选为C++。

typedef int ElemType;
typedef struct {
    ElemType data[MaxSize];
    int length;
}SqList;

//打印顺序表
void PrintList(SqList L){
    for (int i = 0; i <L.length ; i++) {
        printf("%3d",L.data[i]);
    }
    printf("\n");
}


//实现函数的插入,i代表插入位置 ele代表插入元素
bool ListInsert(SqList &L,int i,ElemType ele){
    int j;
    for ( j = L.length; j >i-1 ; j--) {
        L.data[j]=L.data[j-1];
    }
    L.data[i-1]=ele;//插入值
    L.length++;//数组长度增加
    return true;
}
//实现函数的删除,i代表删除位置
bool DeleteList(SqList &L,ElemType i)
{
    //判断函数删除位置是否合法
    if(i<1 || i>L.length)
    {
        return false;
    } else{
        for (int j =i-1; j <L.length-1 ; j++) {
            L.data[j]=L.data[j+1];
        }
        L.length--;
        return true;
    }

}
int main() {
    int value;//改变值
    int pos;//删除位置
    bool ret;//用来接受函数返回值
    SqList L;
    L.data[0]=1;
    L.data[1]=2;
    L.data[2]=3;
    L.length=3;
    scanf("%d",&value);
    ret=ListInsert(L,2,value);
    if(ret){
        PrintList(L);
    }
    scanf("%d",&pos);
    ret=DeleteList(L,pos);
    if(ret){
        PrintList(L);
    } else{
        printf("false");
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值