zoukankan      html  css  js  c++  java
  • 静态链表

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





  • 相关阅读:
    JQ对JSON的增删改
    Debug编辑通过转Release找不到命名空间
    Codeforces Round #740(Div. 2)
    2021“MINIEYE杯”中国大学生算法设计超级联赛(10)
    2021“MINIEYE杯”中国大学生算法设计超级联赛(8)
    Codeforces Round #737 (Div. 2)
    2021“MINIEYE杯”中国大学生算法设计超级联赛(7)
    2021牛客暑期多校训练营8
    2021牛客暑期多校训练营7
    2021“MINIEYE杯”中国大学生算法设计超级联赛(6)
  • 原文地址:https://www.cnblogs.com/zhuzhenfeng/p/4626530.html
Copyright © 2011-2022 走看看