数据结构算法分析——C语言描述 第三章的单链表

很基础的东西。走一遍流程。有人说学编程最简单最笨的方法就是把书上的代码敲一遍。这个我是头文件是照抄的。.c源文件自己实现。

list.h

  1. typedef int ElementType;
  2. #ifndef _List_H
  3. #define _List_H
  4. struct Node;
  5. typedef struct Node *PtrToNode;
  6. typedef PtrToNode List;
  7. typedef PtrToNode Position;
  8. List CreatList();
  9. List MakeEmpty(List L);
  10. int IsEmpty(List L);
  11. int IsLast(Position P, List L);
  12. Position Find(ElementType X, List L);
  13. void Delete(ElementType X, List L);
  14. Position FindPrevious(ElementType X, List L);
  15. void Insert(ElementType X, Position P);
  16. void DeleteList(List L);
  17. Position Header(List L);
  18. Position First(List L);
  19. Position Advance(Position P);
  20. ElementType Retrieve(Position P);
  21. #endif

list.c

  1. #include"list.h"
  2. #include<stdlib.h>
  3. #include"fatal.h"
  4. struct  Node
  5. {
  6. ElementType Element;
  7. Position Next;
  8. };
  9. List CreatList() {
  10. List l = malloc(sizeof(struct Node));
  11. if (l == NULL)
  12. Error("out of memory");
  13. l->Next = NULL;
  14. return l;
  15. }
  16. List MakeEmpty(List L) {
  17. if (L != NULL)
  18. DeleteList(L);
  19. L = malloc(sizeof(struct Node));
  20. if (L == NULL)
  21. FatalError("Out of memory");
  22. L->Next = NULL;
  23. return L;
  24. }
  25. int IsEmpty(List L) {
  26. return L->Next == NULL;
  27. }
  28. int IsLast(Position P, List L) {
  29. return P->Next == NULL;
  30. }
  31. Position Find(ElementType X, List L) {
  32. Position P;
  33. P = L->Next;
  34. while (P != NULL&&P->Element != X)
  35. {
  36. P = P->Next;
  37. }
  38. return P;
  39. }
  40. void Delete(ElementType X, List L) {
  41. Position P;
  42. P = FindPrevious(X, L);
  43. if (!IsLast(P, L)) {
  44. Position TmpCell = P->Next;
  45. P->Next = TmpCell->Next;
  46. free(TmpCell);
  47. }
  48. }
  49. Position FindPrevious(ElementType X, List L) {
  50. Position P;
  51. P = L;
  52. while (P->Next != NULL&&P->Next->Element != X)
  53. P = P->Next;
  54. return P;
  55. }
  56. void Insert(ElementType X, Position P) {
  57. Position tmpCell;
  58. tmpCell = malloc(sizeof(struct Node));
  59. if (tmpCell == NULL)
  60. FatalError("Out of space!!");
  61. tmpCell->Element = X;
  62. tmpCell->Next = P->Next;
  63. P->Next = tmpCell;
  64. }
  65. void DeleteList(List L) {
  66. Position p;
  67. p = L->Next;
  68. L->Next = NULL;
  69. while (p != NULL){
  70. Position tmp;
  71. tmp = p->Next;
  72. free(p);
  73. p = tmp;
  74. }
  75. }
  76. Position Header(List L) {
  77. return L;
  78. }
  79. Position First(List L) {
  80. return L->Next;
  81. }
  82. Position Advance(Position P) {
  83. return P->Next;
  84. }
  85. ElementType Retrieve(Position P) {
  86. return P->Element;
  87. }

fatal.h

    1. #include<stdio.h>
    2. #include<stdlib.h>
    3. #define Error(Str) FatalError(Str)
    4. #define FatalError(Str) fprintf(stderr,"%s\n",Str),exit(1)

数据结构与算法分析——C语言描述 第三章的单链表的更多相关文章

  1. 《数据结构与算法分析——C语言描述》ADT实现(NO.00) : 链表(Linked-List)

    开始学习数据结构,使用的教材是机械工业出版社的<数据结构与算法分析——C语言描述>,计划将书中的ADT用C语言实现一遍,记录于此.下面是第一个最简单的结构——链表. 链表(Linked-L ...

  2. 【数据结构与算法分析——C语言描述】第二章总结 算法分析

    算法 算法(algorithm)是为求解一个问题需要遵循的.被清楚地指定的简单指令的集合. 数学基础 四个定义: 1.大O表示法: 如果存在正常数 c 和 n0 使得当 N ≥ n0时,T(N) ≤ ...

  3. 【数据结构与算法分析——C语言描述】第一章总结 引论

    这一章主要复习了一些数学知识,像指数.对数.模运算.级数公式:还有2种证明方法,归纳假设法和反证法.所幸以前学过,重新拾捡起来也比较轻松. 简要地复习了递归,提出了编写递归例程的四条基本法则: 基准情 ...

  4. 最小正子序列(序列之和最小,同时满足和值要最小)(数据结构与算法分析——C语言描述第二章习题2.12第二问)

    #include "stdio.h" #include "stdlib.h" #define random(x) (rand()%x) void creat_a ...

  5. C语言学习书籍推荐《数据结构与算法分析:C语言描述(原书第2版)》下载

    维斯 (作者), 冯舜玺 (译者) <数据结构与算法分析:C语言描述(原书第2版)>内容简介:书中详细介绍了当前流行的论题和新的变化,讨论了算法设计技巧,并在研究算法的性能.效率以及对运行 ...

  6. 《数据结构与算法分析-Java语言描述》 分享下载

    书籍信息 书名:<数据结构与算法分析-Java语言描述> 原作名:Data Structures and Algorithm Analysis in Java 作者: 韦斯 (Mark A ...

  7. 读书笔记:《数据结构与算法分析Java语言描述》

    目录 第 3 章 表.栈和队列 3.2 表 ADT 3.2.1 表的简单数组实现 3.2.2 简单链表 3.3 Java Collections API 中的表 3.3.1 Collection 接口 ...

  8. 《数据结构与算法分析:C语言描述_原书第二版》CH3表、栈和队列_reading notes

    表.栈和队列是最简单和最基本的三种数据结构.基本上,每一个有意义的程序都将明晰地至少使用一种这样的数据结构,比如栈在程序中总是要间接地用到,不管你在程序中是否做了声明. 本章学习重点: 理解抽象数据类 ...

  9. 《数据结构与算法分析——C语言描述》ADT实现(NO.04) : AVL树(AVL-Tree)

    上次我们已经实现了普通的二叉查找树.利用二叉查找树,可以用O(logN)高度的树状结构存储和查找数据,提高了存储和查找的效率. 然而,考虑一种极端情形:依次插入1,2,3,4,5,6,7,8,9九个元 ...

随机推荐

  1. 安装rabbitmq

    安装配置epel源 $ rpm -ivh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm 安装erlan ...

  2. 单节点下多个Tomcat服务器并存的端口号配置

    一个服务器节点同时安装多个tomcat服务器时,如果仅仅修改访问端口号则会提示端口冲突启动失败,还需要修改另外端口号解决,一共需要修改3处地方,修改如下: 编辑配置文件:server.xml 1.首先 ...

  3. go:系统参数or函数--未完

    系统参数: os.Args 存放命令参数的字符串数组,其中os.Arg[0]为命令本身的路径,其余项存放输入的参数 例:$ go run myapp.exe -d /home os.Args[0]: ...

  4. Nginx与Apache的比较

    Nginx与Apache的比较 Nginx相对于Apache的优点 轻量级.同样起web服务,比apache占用更少的资源和内存 抗并发.nginx处理请求是异步非阻塞,而apache则是阻塞型.在高 ...

  5. C# 如何用多个字符串来切分字符串并去除空格

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.D ...

  6. HDU3571 N-dimensional Sphere(高斯消元 同模方程)

    每个点到中心距离相等,以第0个点为参考,其他n个点到中心距等于点0到中心距,故可列n个方程 列出等式后二次未知数相消,得到线性方程组 将每个数加上1e17,求答案是再减去,求解时对一个2 * (1e1 ...

  7. Excel word “由于本机的限制_该操作已被取消_请与管理员联系”的已生效解决办法 (转 )

    正常解决方法: 1.打开开始菜单,在运行里输入regedit,回车 2.在注册表中,导航到HKEY_CURRENT_USER\Software\Classes\.html 项 3.在默认项上点右键选择 ...

  8. iOS--关于同步下载

    { NSMutableArray *_dataList; } [self loadDataWithPage:]; [self loadDataWithURLConnection]; //记得初始化数组 ...

  9. Multiple annotations found at this line

    Multiple annotations found at this line 在使用MyEclipse的时候,通过MVN导入项目时候,webapp下面的JSP页面报了如下的错误: 这种情况通常的原因 ...

  10. 摘要: Linux下which、whereis、locate、find命令的区别

    我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索.这些是从网上找到的资料,因为有时很长时间不会用到,当要用的时候经常弄混了,所以放到这里方便使用. which    ...