静态顺序表

静态顺序表

声明的结构体属性中,直接采用数组,因此能实现直接定位,但也正因为是数组,导致不能扩容。只能静态使用

源码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#include "stdio.h"
#define MAX 100

typedef struct SqeList
{
int elem[MAX];
int length;
}SqeList;

void init(SqeList& L) {
for (int i = 0; i < 10; i++)
{
L.elem[i] = i;
L.length++;
}
}

void insert(SqeList& L,int index,int value) {
if (index < 0 || index >L.length) {
printf("插入索引位置超出边界");
return;
}
if (L.length == MAX) {
printf("静态数组已满,无法再插入元素");
return;
}
for (int i = L.length-1; i >= index; i--)
{
L.elem[i + 1] = L.elem[i];
}
L.elem[index] = value;
L.length++;
}

void del(SqeList& L, int index) {
if (index < 0 || index > L.length - 1) {
printf("删除索引位置超出边界");
return;
}
for (int i = index; i < L.length-1; i++)
{
L.elem[i] = L.elem[i + 1];
}
L.length--;
}


void modify(SqeList& L,int index, int value) {
if (index < 0 || index > L.length-1) {
printf("修改索引位置超出边界");
return;
}
L.elem[index] = value;
}

int select(SqeList& L, int index) {
if (index < 0 || index > L.length - 1) {
printf("查询索引位置超出边界");
return -1;
}
int value = L.elem[index];
return value;
}

void print(SqeList& L) {
for (int i = 0; i < L.length; i++)
{
printf("%d", L.elem[i]);
}
printf("\n");
}

int main()
{
SqeList L;
L.length = 0;
init(L);
print(L);

int insert_index = 0;
int insert_value = 9;
insert(L,insert_index,insert_value);
print(L);

int del_index = 1;
del(L, del_index);
print(L);


int modify_index = 2;
int modify_value = 9;
modify(L, modify_index, modify_value);
print(L);


int select_index = 9;
int select_value = select(L, select_index);
printf("%d",select_value);
return 0;
}



运行效果图

静态顺序表


静态顺序表
http://oowatermelon.github.io/OoWaterMelonS/2022/11/16/静态顺序表/
作者
OoWaterMelonS Shao
发布于
2022年11月16日
许可协议