数据结构c语言顺序表
时间: 2023-07-21 19:03:31 浏览: 106
顺序表是一种常见的数据结构,它可以用 C 语言来实现。顺序表是一个一维数组,它的元素按照线性的顺序存储在数组中,而且数组的长度是固定的。下面是一个简单的顺序表的 C 语言实现:
```c
#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 100 // 最大长度
typedef struct {
int data[MAX_SIZE]; // 数据
int length; // 当前长度
} SqList;
// 初始化顺序表
void init(SqList *list) {
list->length = 0;
}
// 插入元素
void insert(SqList *list, int index, int value) {
if (index < 0 || index > list->length || list->length >= MAX_SIZE) {
printf("插入位置无效或顺序表已满\n");
return;
}
for (int i = list->length - 1; i >= index; i--) {
list->data[i + 1] = list->data[i];
}
list->data[index] = value;
list->length++;
}
// 删除元素
void remove(SqList *list, int index) {
if (index < 0 || index >= list->length) {
printf("删除位置无效\n");
return;
}
for (int i = index + 1; i < list->length; i++) {
list->data[i - 1] = list->data[i];
}
list->length--;
}
// 获取元素
int get(SqList *list, int index) {
if (index < 0 || index >= list->length) {
printf("获取位置无效\n");
return -1;
}
return list->data[index];
}
// 修改元素
void set(SqList *list, int index, int value) {
if (index < 0 || index >= list->length) {
printf("修改位置无效\n");
return;
}
list->data[index] = value;
}
// 输出顺序表
void print(SqList *list) {
for (int i = 0; i < list->length; i++) {
printf("%d ", list->data[i]);
}
printf("\n");
}
int main() {
SqList list;
init(&list);
insert(&list, 0, 1);
insert(&list, 1, 3);
insert(&list, 1, 2);
print(&list); // 1 2 3
remove(&list, 1);
print(&list); // 1 3
set(&list, 1, 4);
print(&list); // 1 4
int value = get(&list, 1);
printf("%d\n", value); // 4
return 0;
}
```
在上面的代码中,我们定义了一个 `SqList` 结构体来表示顺序表,包含一个 `data` 数组和一个 `length` 变量。初始化顺序表的方法是将 `length` 设置为 0,插入元素的方法是将插入位置之后的元素依次后移,然后将新元素插入到指定位置;删除元素的方法是将删除位置之后的元素依次前移,然后将顺序表长度减 1;获取元素的方法是返回指定位置的元素;修改元素的方法是将指定位置的元素替换为新的元素。
阅读全文