数据结构与算法分析——C语言描述 第三章的单链表
很基础的东西。走一遍流程。有人说学编程最简单最笨的方法就是把书上的代码敲一遍。这个我是头文件是照抄的。.c源文件自己实现。
list.h
- typedef int ElementType;
- #ifndef _List_H
- #define _List_H
- struct Node;
- typedef struct Node *PtrToNode;
- typedef PtrToNode List;
- typedef PtrToNode Position;
- List CreatList();
- List MakeEmpty(List L);
- int IsEmpty(List L);
- int IsLast(Position P, List L);
- Position Find(ElementType X, List L);
- void Delete(ElementType X, List L);
- Position FindPrevious(ElementType X, List L);
- void Insert(ElementType X, Position P);
- void DeleteList(List L);
- Position Header(List L);
- Position First(List L);
- Position Advance(Position P);
- ElementType Retrieve(Position P);
- #endif
list.c
- #include"list.h"
- #include<stdlib.h>
- #include"fatal.h"
- struct Node
- {
- ElementType Element;
- Position Next;
- };
- List CreatList() {
- List l = malloc(sizeof(struct Node));
- if (l == NULL)
- Error("out of memory");
- l->Next = NULL;
- return l;
- }
- List MakeEmpty(List L) {
- if (L != NULL)
- DeleteList(L);
- L = malloc(sizeof(struct Node));
- if (L == NULL)
- FatalError("Out of memory");
- L->Next = NULL;
- return L;
- }
- int IsEmpty(List L) {
- return L->Next == NULL;
- }
- int IsLast(Position P, List L) {
- return P->Next == NULL;
- }
- Position Find(ElementType X, List L) {
- Position P;
- P = L->Next;
- while (P != NULL&&P->Element != X)
- {
- P = P->Next;
- }
- return P;
- }
- void Delete(ElementType X, List L) {
- Position P;
- P = FindPrevious(X, L);
- if (!IsLast(P, L)) {
- Position TmpCell = P->Next;
- P->Next = TmpCell->Next;
- free(TmpCell);
- }
- }
- Position FindPrevious(ElementType X, List L) {
- Position P;
- P = L;
- while (P->Next != NULL&&P->Next->Element != X)
- P = P->Next;
- return P;
- }
- void Insert(ElementType X, Position P) {
- Position tmpCell;
- tmpCell = malloc(sizeof(struct Node));
- if (tmpCell == NULL)
- FatalError("Out of space!!");
- tmpCell->Element = X;
- tmpCell->Next = P->Next;
- P->Next = tmpCell;
- }
- void DeleteList(List L) {
- Position p;
- p = L->Next;
- L->Next = NULL;
- while (p != NULL){
- Position tmp;
- tmp = p->Next;
- free(p);
- p = tmp;
- }
- }
- Position Header(List L) {
- return L;
- }
- Position First(List L) {
- return L->Next;
- }
- Position Advance(Position P) {
- return P->Next;
- }
- ElementType Retrieve(Position P) {
- return P->Element;
- }
fatal.h
- #include<stdio.h>
- #include<stdlib.h>
- #define Error(Str) FatalError(Str)
- #define FatalError(Str) fprintf(stderr,"%s\n",Str),exit(1)
数据结构与算法分析——C语言描述 第三章的单链表的更多相关文章
- 《数据结构与算法分析——C语言描述》ADT实现(NO.00) : 链表(Linked-List)
开始学习数据结构,使用的教材是机械工业出版社的<数据结构与算法分析——C语言描述>,计划将书中的ADT用C语言实现一遍,记录于此.下面是第一个最简单的结构——链表. 链表(Linked-L ...
- 【数据结构与算法分析——C语言描述】第二章总结 算法分析
算法 算法(algorithm)是为求解一个问题需要遵循的.被清楚地指定的简单指令的集合. 数学基础 四个定义: 1.大O表示法: 如果存在正常数 c 和 n0 使得当 N ≥ n0时,T(N) ≤ ...
- 【数据结构与算法分析——C语言描述】第一章总结 引论
这一章主要复习了一些数学知识,像指数.对数.模运算.级数公式:还有2种证明方法,归纳假设法和反证法.所幸以前学过,重新拾捡起来也比较轻松. 简要地复习了递归,提出了编写递归例程的四条基本法则: 基准情 ...
- 最小正子序列(序列之和最小,同时满足和值要最小)(数据结构与算法分析——C语言描述第二章习题2.12第二问)
#include "stdio.h" #include "stdlib.h" #define random(x) (rand()%x) void creat_a ...
- C语言学习书籍推荐《数据结构与算法分析:C语言描述(原书第2版)》下载
维斯 (作者), 冯舜玺 (译者) <数据结构与算法分析:C语言描述(原书第2版)>内容简介:书中详细介绍了当前流行的论题和新的变化,讨论了算法设计技巧,并在研究算法的性能.效率以及对运行 ...
- 《数据结构与算法分析-Java语言描述》 分享下载
书籍信息 书名:<数据结构与算法分析-Java语言描述> 原作名:Data Structures and Algorithm Analysis in Java 作者: 韦斯 (Mark A ...
- 读书笔记:《数据结构与算法分析Java语言描述》
目录 第 3 章 表.栈和队列 3.2 表 ADT 3.2.1 表的简单数组实现 3.2.2 简单链表 3.3 Java Collections API 中的表 3.3.1 Collection 接口 ...
- 《数据结构与算法分析:C语言描述_原书第二版》CH3表、栈和队列_reading notes
表.栈和队列是最简单和最基本的三种数据结构.基本上,每一个有意义的程序都将明晰地至少使用一种这样的数据结构,比如栈在程序中总是要间接地用到,不管你在程序中是否做了声明. 本章学习重点: 理解抽象数据类 ...
- 《数据结构与算法分析——C语言描述》ADT实现(NO.04) : AVL树(AVL-Tree)
上次我们已经实现了普通的二叉查找树.利用二叉查找树,可以用O(logN)高度的树状结构存储和查找数据,提高了存储和查找的效率. 然而,考虑一种极端情形:依次插入1,2,3,4,5,6,7,8,9九个元 ...
随机推荐
- postgresql 中replace 函数
select replace(字段名,E'\r','') from 表名 where 字段名 like E'%\r%';: 查看修改后结果,并不真实修改数据库 update 表名 set 字段名=r ...
- MySQL 5.7 学习:新增配置参数
背景: 继上次介绍 初识 MySQL 5.6 新功能.参数完之后,刚好MySQL 5.7又GA了,在官方测试里看到,MySQL5.7在功能.性能.可用性.安全和监控上又提升了很高.现在看看和MySQL ...
- Android Studio在创建/导入项目的时候,一直处于building “XXX”gradle project info的解决办法
Android Studio在新建项目或者导入项目的时候,可能会一直处于building “XXX”gradle project info的状态,而且还取消不了,无奈之下只能干掉进程... 还有一种情 ...
- ubuntu 创建用户
http://www.jb51.net/article/45848.htm 创建用户
- css中一些常用技巧
// css中引入字体文件 @font-face { font-family: msyh; /*这里是说明调用来的字体名字*/ src: url('../font/wryh.ttf'); /*这里是字 ...
- 根据字符长度动态确定UIlabel宽高
iOS7中用以下方法 - (CGSize)sizeWithAttributes:(NSDictionary *)attrs; 替代过时的iOS6中的- (CGSize)sizeWithFont:(UI ...
- node的安装
1.打开node官网 https://nodejs.org/en/ 下载最新版node安装包 v6.2.2 版本自带npm包,比较方便使用.下载之后就正常的常规安装即可. 2.查看是否安装成功 ...
- October 18th, Week 43rd Tuesday, 2016
Live as if you were to die tomorrow. 将每一天都当作人生的最后一天来活. If I were to die tomorrow, I may choose to en ...
- HTML是什么?如何使用?
①我们首先打开桌面DW网页开发器. 也可以是其他的开发器. ②打开之后那么我们创建一个新的文档: 点击创建之后出现下图: 一般我们不管用哪种网页开发器,都会最先呈现上图的状态,那么下面来解读一下这些文 ...
- C++ 基础知识复习(二)
异常处理部分: 23. 在c++的异常处理中,除了提供异常的关键字语法支持以外,其标准库中支持异常处理而封装异常类也很好的为应用程序中异常处理判断使用提供直接的帮助.C++语言中针对异常处理提供了三个 ...