C语言线性表之顺序表
作者:野牛程序员:2023-08-23 11:47:29C语言阅读 2707
顺序表(Sequential List),也称为数组,是一种基本的线性表数据结构,其中元素在内存中按顺序存储,可以通过索引访问。在 C 语言中,数组是顺序表的一种实现。以下是一个简单的顺序表的示例代码:
#include <stdio.h> #include <stdbool.h> #define MAX_SIZE 100 // 顺序表的最大容量 // 定义顺序表结构 typedef struct { int data[MAX_SIZE]; int length; } SeqList; // 初始化顺序表 void initSeqList(SeqList *list) { list->length = 0; } // 判断顺序表是否为空 bool isEmpty(SeqList *list) { return list->length == 0; } // 判断顺序表是否已满 bool isFull(SeqList *list) { return list->length == MAX_SIZE; } // 在指定位置插入元素 bool insert(SeqList *list, int index, int value) { if (index < 0 || index > list->length || isFull(list)) { return false; } for (int i = list->length; i > index; i--) { list->data[i] = list->data[i - 1]; } list->data[index] = value; list->length++; return true; } // 删除指定位置的元素 bool removeAt(SeqList *list, int index) { if (index < 0 || index >= list->length || isEmpty(list)) { return false; } for (int i = index; i < list->length - 1; i++) { list->data[i] = list->data[i + 1]; } list->length--; return true; } // 获取指定位置的元素 bool get(SeqList *list, int index, int *value) { if (index < 0 || index >= list->length) { return false; } *value = list->data[index]; return true; } int main() { SeqList list; initSeqList(&list); insert(&list, 0, 10); insert(&list, 1, 20); insert(&list, 1, 15); int value; if (get(&list, 1, &value)) { printf("索引 1 处的元素:%d\\n", value); } removeAt(&list, 0); printf("顺序表内容:"); for (int i = 0; i < list.length; i++) { printf("%d ", list.data[i]); } printf("\\n"); return 0; }
在这段代码中,SeqList
结构表示顺序表,其中 data
数组用于存储元素,length
表示当前顺序表的长度。initSeqList
函数用于初始化顺序表,isEmpty
和 isFull
函数分别判断顺序表是否为空和已满,insert
函数在指定位置插入元素,removeAt
函数删除指定位置的元素,get
函数获取指定位置的元素。
顺序表在内存中是连续存储的,访问元素的时间复杂度为 O(1),但插入和删除操作可能需要移动大量元素,时间复杂度为 O(n)。在实际应用中,顺序表适用于需要频繁随机访问元素的场景。
野牛程序员教少儿编程与信息学奥赛-微信|电话:15892516892

- 上一篇:C语言线性表之线性链表(单链表)
- 下一篇:C语言函数的递归调用和递归函数