单链表List的C实现
头文件————————————————————————————————
//单链表的实现
#ifndef _LIST_H_
#define _LIST_H_ #include <stdlib.h>
#define Element int
struct node
{
Element data;
struct node *next;
};
typedef struct node* PtrToNode;
typedef PtrToNode Position;
typedef Position List;
List MakeEmpty(List L);
int IsEmpty(List L);
int IsLast(Position P, List L);
List CreateEmptyList();
Position Find(Element X, List L);
void Delete(Element X, List L);
Position FindPrevious(Element X, List L);//查找失败则返回链表的最后一个元素
void Insert(Element X, Position P, List L);//在P的后面插入新元素X
void PushBack(Element X, List L);
void PushFront(Element X, List L);
void DeleteList(List L);
Position Header(List L);
Position First(List L);
Position Advance(Position P, List L);//得到P的前一个位置
Element Retrieve(Position P);
#endif
//单链表的实现
#include "./List.h"
List MakeEmpty(List L)
{
if (NULL == L)
return L;
Position p = First(L);
Position tmp = p;
while(NULL != p)
{
tmp = p->next;
free(p);
p = tmp;
}
L->next = NULL;
return L;
}
int IsEmpty(List L)
{
return First(L) == NULL;
}
int IsLast(Position P, List L)
{
return P->next == NULL;
}
List CreateEmptyList()
{
List L = (List)malloc(sizeof(struct node));
if(NULL == L) return NULL;
L->next = NULL;
return L;
}
Position Find(Element X, List L)
{
if(NULL == L) return NULL;
Position p = First(L);
while(NULL != p && p->data != X)
p = p->next;
return p;
}
void Delete(Element X, List L)
{
if(NULL == L) return ;
Position prev = FindPrevious(X, L);
if(!IsLast(prev, L))
{
Position tmp = prev->next;
prev->next = tmp->next;
free(tmp);
}
}
Position FindPrevious(Element X, List L)//查找失败则返回链表的最后一个元素
{
if(NULL == L) return NULL;
Position prev = Header(L);
while(NULL != prev->next && X != prev->next->data)
prev = prev->next;
return prev;
}
void Insert(Element X, Position P, List L)//在P的后面插入新元素X
{
if(NULL == L) return ;
Position tmp = (Position)malloc(sizeof(struct node));
if(NULL == tmp) return ;
tmp->data = X;
tmp->next = P->next;
P->next = tmp
}
void PushBack(Element X, List L)
{
if(NULL == L) return ;
Position pos = Header(L);
while(NULL != pos->next)
pos = pos->next;
Position tmp = (Position)malloc(sizeof(struct node));
if(NULL == tmp) return ;
tmp->data = X;
tmp->next = NULL;
pos->next = tmp;
}
void PushFront(Element X, List L)
{
if(NULL == L) return ;
Position pos = L->next;
Position tmp = (Position)malloc(sizeof(struct node));
if(NULL == tmp) return ;
tmp->data = X;
tmp->next = pos;
L->next = tmp;
}
void DeleteList(List L)
{
MakeEmpty(L);
free(L);
}
Position Header(List L)
{
return L;
}
Position First(List L)
{
if(NULL == L) return NULL;
return L->next;
}
Position Advance(Position P, List L)//得到P的前一个位置
{
if(NULL == L) return NULL;
Position prev = Header(L);
while(NULL != prev && prev->next != P)
prev = prev->next;
return prev;
}
Element Retrieve(Position P)
{
return P->data;
}
单链表List的C实现的更多相关文章
- 时间复杂度分别为 O(n)和 O(1)的删除单链表结点的方法
有一个单链表,提供了头指针和一个结点指针,设计一个函数,在 O(1)时间内删除该结点指针指向的结点. 众所周知,链表无法随机存储,只能从头到尾去遍历整个链表,遇到目标节点之后删除之,这是最常规的思路和 ...
- 单链表的C++实现(采用模板类)
采用模板类实现的好处是,不用拘泥于特定的数据类型.就像活字印刷术,制定好模板,就可以批量印刷,比手抄要强多少倍! 此处不具体介绍泛型编程,还是着重叙述链表的定义和相关操作. 链表结构定义 定义单链表 ...
- Java实现单链表的各种操作
Java实现单链表的各种操作 主要内容:1.单链表的基本操作 2.删除重复数据 3.找到倒数第k个元素 4.实现链表的反转 5.从尾到头输出链表 6.找到中间节点 7.检测链表是否有环 8.在 ...
- [LeetCode] Linked List Cycle II 单链表中的环之二
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- c++单链表基本功能
head_LinkNode.h /*单链表类的头文件*/#include<assert.h>#include"compare.h"typedef int status; ...
- 单链表、循环链表的JS实现
数据结构系列前言: 数据结构作为程序员的基本知识,需要我们每个人牢牢掌握.近期我也展开了对数据结构的二次学习,来弥补当年挖的坑...... 当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结 ...
- C代码实现非循环单链表
C代码实现非循环单链表, 直接上代码. # include <stdio.h> # include <stdlib.h> # include <malloc.h> ...
- 分离的思想结合单链表实现级联组件:CascadeView
本文介绍自己最近做省市级联的类似的级联功能的实现思路,为了尽可能地做到职责分离跟表现与行为分离,这个功能拆分成了2个组件并用到了单链表来实现关键的级联逻辑,下一段有演示效果的gif图.虽然这是个很常见 ...
- 数据结构:单链表结构字符串(python版)添加了三个新功能
#!/urs/bin/env python # -*- coding:utf-8 -*- #异常类 class stringTypeError(TypeError): pass #节点类 class ...
- 数据结构:单链表结构字符串(python版)改进
此篇文章的replace实现了字符串类的多次匹配,但依然有些不足. 因为python字符串对象为不变对象,所以replace方法并不修改原先的字符串,而是返回修改后的字符串. 而此字符串对象时用单链表 ...
随机推荐
- EndPoint详解
EndPoint详解 EndPoint主要用于暴露一些SpringMvc内部运行的信息,通常是通过SpringMvc的请求地址获取相关信息.如/health获取健康检查信息. 简单单元测试 @Test ...
- 深入学习系列--Data Structure--02字符串
字符串可以说是我们实际工作中使用最多的数据类型了,常见的字符串操作包括链接.取子串.格式化等.这部分内容总体来说比较容易理解,最难的部分要数字符串的模式匹配方法了,尤其是KMP算法,需要通过实践加以记 ...
- QueryTask查询结果最多500条的问题
参考: http://dingtao-wgs.blog.163.com/blog/static/5026071420129813059865/ 上面文章中给出的解决方法:今天在做querytask的时 ...
- Swift 中范围和区间如何使用?
虽然现在swift语言已经发展到了2.0版了,但是相信很多学习iOS开发的童鞋仍对swift语言存在各种各样的疑问,今天小编将为大家详细介绍swift中的范围和区间,下面我们一起来看看吧. Range ...
- PHP中常用的正则表达式由哪些元素构成?
在程序开发中,我们常常要用到正则表达式,对于新手来说,很多时候知道正则表达式是怎么回事,但当真正需要使用的时候,却不知该用什么函数,具体的修饰符也比较混乱.下面小编就为大家整理了一些php正则表达式中 ...
- C++Builder RAD Studio XE, UTF-8 String 转换为 char * 字符串的最简单方式, 常用于sqlite3开发
前段时间突然使用sqlite3开发,中间需要用中文,XE的缺省char*直接使用中文,在sqlite *.db3的数据库表格中显示是乱码,用数据库管理器来浏览等管理时非常不便. 于是决定还是使用utf ...
- Cocos2dx.3x入门三部曲-Hello Game项目创建(二)
一.前提: 完成cocos2d-x-3.x开发环境的安装配置. 具体参考:Cocos2d-x.3x_软件配置篇 二.本篇目标: l 创建一个名为hello game的cocos2dx 3.3的项目 ...
- windows 2012 试用180天
windows server 2012 官方下载,可以使用180天, 快到期的时候执行以下命令 slmgr.vbs -rearm
- 【转载】UEditor前端配置项说明
UEditor 的配置项分为两类:前端配置项 和 后端配置项 后端配置项具体看这个文档L:后端配置项说明 本文档介绍如何通过设置前端配置项,定制编辑器的特性,配置方法主要通过修改ueditor.con ...
- 【C】——幻方算法
一.幻方按照阶数可分成了三类,即奇数阶幻方.双偶阶幻方.单偶阶幻方. 二.奇数阶幻方(劳伯法) 奇数阶幻方最经典的填法是罗伯法.填写的方法是: 把1(或最小的数)放在第一行正中:按以下规律排列剩下的( ...