C语言中实现顺序表的插入、删除和更新操作(附带源码)

这篇具有很好参考价值的文章主要介绍了C语言中实现顺序表的插入、删除和更新操作(附带源码)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

C语言中,顺序表是一种线性表的存储结构,可以通过数组来实现。以下是顺序表的插入、删除和更新操作的基本示例:

#include <stdio.h>

#define MAX_SIZE 100

// 定义顺序表结构
typedef struct {
    int data[MAX_SIZE];
    int length;
} SeqList;

// 插入操作
int insert(SeqList *list, int position, int value) {
    // 判断插入位置是否合法
    if (position < 1 || position > list->length + 1) {
        printf("插入位置不合法\n");
        return 0; // 插入失败
    }

    // 判断顺序表是否已满
    if (list->length >= MAX_SIZE) {
        printf("顺序表已满,无法插入\n");
        return 0; // 插入失败
    }

    // 将插入位置之后的元素依次后移
    for (int i = list->length; i >= position; i--) {
        list->data[i] = list->data[i - 1];
    }

    // 插入新元素
    list->data[position - 1] = value;

    // 长度加1
    list->length++;

    return 1; // 插入成功
}

int main() {
    SeqList myList = {{1, 2, 3, 4, 5}, 5};

    // 在第3个位置插入元素6
    insert(&myList, 3, 6);

    // 打印插入后的顺序表
    for (int i = 0; i < myList.length; i++) {
        printf("%d ", myList.data[i]);
    }

    return 0;
}
  1. 删除操作:
#include <stdio.h>

// 定义顺序表结构
typedef struct {
    int data[MAX_SIZE];
    int length;
} SeqList;

// 删除操作
int delete(SeqList *list, int position) {
    // 判断删除位置是否合法
    if (position < 1 || position > list->length) {
        printf("删除位置不合法\n");
        return 0; // 删除失败
    }

    // 将删除位置之后的元素依次前移
    for (int i = position; i < list->length; i++) {
        list->data[i - 1] = list->data[i];
    }

    // 长度减1
    list->length--;

    return 1; // 删除成功
}

int main() {
    SeqList myList = {{1, 2, 3, 4, 5}, 5};

    // 删除第3个位置的元素
    delete(&myList, 3);

    // 打印删除后的顺序表
    for (int i = 0; i < myList.length; i++) {
        printf("%d ", myList.data[i]);
    }

    return 0;
}
  1. 更新操作:
#include <stdio.h>

// 定义顺序表结构
typedef struct {
    int data[MAX_SIZE];
    int length;
} SeqList;

// 更新操作
int update(SeqList *list, int position, int newValue) {
    // 判断更新位置是否合法
    if (position < 1 || position > list->length) {
        printf("更新位置不合法\n");
        return 0; // 更新失败
    }

    // 更新指定位置的元素值
    list->data[position - 1] = newValue;

    return 1; // 更新成功
}

int main() {
    SeqList myList = {{1, 2, 3, 4, 5}, 5};

    // 更新第3个位置的元素为10
    update(&myList, 3, 10);

    // 打印更新后的顺序表
    for (int i = 0; i < myList.length; i++) {
        printf("%d ", myList.data[i]);
    }

    return 0;
}

这些示例代码演示了如何在C语言中实现顺序表的插入、删除和更新操作。你可以根据需要进行修改和扩展。

希望你也学会了,更多编程请来二当家的素材网:https://www.erdangjiade.com文章来源地址https://www.toymoban.com/news/detail-820473.html

到了这里,关于C语言中实现顺序表的插入、删除和更新操作(附带源码)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包