1. #include "string.h"
    2. #include "ctype.h"
    3. #include "stdio.h"
    4. #include "stdlib.h"
    5. #include "io.h"
    6. #include "math.h"
    7. #include "time.h"
    8. #define OK 1
    9. #define ERROR 0
    10. #define TRUE 1
    11. #define FALSE 0
    12. #define MAXSIZE 1000 /* 存储空间初始分配量 */
    13. typedef int Status; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */
    14. typedef char ElemType; /* ElemType类型根据实际情况而定,这里假设为char */
    15. Status visit(ElemType c)
    16. {
    17. printf("%c ",c);
    18. return OK;
    19. }
    20. /* 线性表的静态链表存储结构 */
    21. typedef struct
    22. {
    23. ElemType data;
    24. int cur; /* 游标(Cursor) ,为0时表示无指向 */
    25. } Component,StaticLinkList[MAXSIZE];
    26. /* 将一维数组space中各分量链成一个备用链表,space[0].cur为头指针,"0"表示空指针 */
    27. Status InitList(StaticLinkList space)
    28. {
    29. int i;
    30. for (i=0; i<MAXSIZE-1; i++)
    31. space[i].cur = i+1;
    32. space[MAXSIZE-1].cur = 0; /* 目前静态链表为空,最后一个元素的cur为0 */
    33. return OK;
    34. }
    35. /* 若备用空间链表非空,则返回分配的结点下标,否则返回0 */
    36. int Malloc_SSL(StaticLinkList space)
    37. {
    38. int i = space[0].cur; /* 当前数组第一个元素的cur存的值 */
    39. /* 就是要返回的第一个备用空闲的下标 */
    40. if (space[0]. cur)
    41. space[0]. cur = space[i].cur; /* 由于要拿出一个分量来使用了, */
    42. /* 所以我们就得把它的下一个 */
    43. /* 分量用来做备用 */
    44. return i;
    45. }
    46. /* 将下标为k的空闲结点回收到备用链表 */
    47. void Free_SSL(StaticLinkList space, int k)
    48. {
    49. space[k].cur = space[0].cur; /* 把第一个元素的cur值赋给要删除的分量cur */
    50. space[0].cur = k; /* 把要删除的分量下标赋值给第一个元素的cur */
    51. }
    52. /* 初始条件:静态链表L已存在。操作结果:返回L中数据元素个数 */
    53. int ListLength(StaticLinkList L)
    54. {
    55. int j=0;
    56. int i=L[MAXSIZE-1].cur;
    57. while(i)
    58. {
    59. i=L[i].cur;
    60. j++;
    61. }
    62. return j;
    63. }
    64. /* 在L中第i个元素之前插入新的数据元素e */
    65. Status ListInsert(StaticLinkList L, int i, ElemType e)
    66. {
    67. int j, k, l;
    68. k = MAXSIZE - 1; /* 注意k首先是最后一个元素的下标 */
    69. if (i < 1 || i > ListLength(L) + 1)
    70. return ERROR;
    71. j = Malloc_SSL(L); /* 获得空闲分量的下标 */
    72. if (j)
    73. {
    74. L[j].data = e; /* 将数据赋值给此分量的data */
    75. for(l = 1; l <= i - 1; l++) /* 找到第i个元素之前的位置 */
    76. k = L[k].cur;
    77. L[j].cur = L[k].cur; /* 把第i个元素之前的cur赋值给新元素的cur */
    78. L[k].cur = j; /* 把新元素的下标赋值给第i个元素之前元素的ur */
    79. return OK;
    80. }
    81. return ERROR;
    82. }
    83. /* 删除在L中第i个数据元素 */
    84. Status ListDelete(StaticLinkList L, int i)
    85. {
    86. int j, k;
    87. if (i < 1 || i > ListLength(L))
    88. return ERROR;
    89. k = MAXSIZE - 1;
    90. for (j = 1; j <= i - 1; j++)
    91. k = L[k].cur;
    92. j = L[k].cur;
    93. L[k].cur = L[j].cur;
    94. Free_SSL(L, j);
    95. return OK;
    96. }
    97. Status ListTraverse(StaticLinkList L)
    98. {
    99. int j=0;
    100. int i=L[MAXSIZE-1].cur;
    101. while(i)
    102. {
    103. visit(L[i].data);
    104. i=L[i].cur;
    105. j++;
    106. }
    107. return j;
    108. printf("\n");
    109. return OK;
    110. }
    111. int main()
    112. {
    113. StaticLinkList L;
    114. Status i;
    115. i=InitList(L);
    116. printf("初始化L后:L.length=%d\n",ListLength(L));
    117. i=ListInsert(L,1,'F');
    118. i=ListInsert(L,1,'E');
    119. i=ListInsert(L,1,'D');
    120. i=ListInsert(L,1,'B');
    121. i=ListInsert(L,1,'A');
    122. printf("\n在L的表头依次插入FEDBA后:\nL.data=");
    123. ListTraverse(L);
    124. i=ListInsert(L,3,'C');
    125. printf("\n在L的“B”与“D”之间插入“C”后:\nL.data=");
    126. ListTraverse(L);
    127. i=ListDelete(L,1);
    128. printf("\n在L的删除“A”后:\nL.data=");
    129. ListTraverse(L);
    130. printf("\n");
    131. return 0;
    132. }