欢迎使用CSDN-markdown编辑器
来源:互联网 发布:统一网络加速器 编辑:程序博客网 时间:2024/06/03 15:43
单链表结构
每个节点依靠储存的下一个节点的内存地址,从而使得一个一个相连接在一起,而不需要考虑位置在哪
- 插入删除操作空间复杂度为O(1)
- 读取某位置节点的空间复杂度O(n)
- 不需要提前分配空间
- 若线性表需要频繁的插入删除操作则应该选择链式
- 结点个数未知的时候采用链式更好
- 指针的应用
链表创建
- 创建带头结点的指针`
- 按照结构体开辟一块内存`
- 头结点指向NULL`
- 其他的初始化置0`
ps:代码来自网络但没毛病,实现方法很多不是唯一·····
typedef struct _tag_LinkList{ LinkListNode header; int Length;}TLinkList;
LinkList *LinkList_Create(){ TLinkList *tmp = NULL; tmp = (TLinkList *)malloc(sizeof(TLinkList)); if (tmp == NULL) { printf("func LinkList_Create()err \n"); return NULL; } memset(tmp, 0, sizeof(TLinkList)); tmp->Length = 0; tmp->header.next = NULL; return tmp;}
销毁
当链表执行完毕后要进行销毁····
直接free掉链表,不要忘记判断是否为空····
void LinkList_Destroy(LinkList *list)
{
if (list == NULL)
{
return;
}
free(list);
return ;
}
清空链表
链表的清空和销毁是不一样的,销毁的话释放了整个内存空间,狗带了就
然而清空的话,保留了内存空间,只是把里面东西弄没了,回到刚刚创建好头指针指向NULL的一个状态
就是相当于,俩人分手了销毁的是自杀,清空是回到单身狗状态
- 判断链表是否已经空了
- 链表长度置为零
- 清空头结点
void LinkList_Clear(LinkList *list){ TLinkList *tList = NULL; tList = (TLinkList *)list; if (tList == NULL) { return; } tList->Length = 0; tList->header.next = NULL; return ;}
获取链表长度
- 判断链表是否为空
- 直接返回长度即可
int LinkList_Length(LinkList *list){ TLinkList *tList = NULL; tList = (TLinkList *)list; if (tList == NULL) { return -1; } return tList->Length;}
链表的插入
就 相当于一堆人手拉手好好的走,突然隔壁老王来了要站在张翠花和赵桂花中间,张翠花和赵桂花拉着的手就得松开,俩人都拉着老王
- 需要辅助指针用来从头部开始蹦跶走走走走到指向要插入的地方
- 需要辅助指针变量接过来之前搞好的list
- 需要知道插入位置
- 错误判断:list为空,插入位置<0,要来插队的结点为空,三选一就没法玩儿了
链表长度再+1!!!
int LinkList_Insert(LinkList *list, LinkListNode *node, int pos){ int i = 0; LinkListNode *current = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list == NULL || node == NULL || pos < 0) { return -1; } current = &(tList->header); for (i = 0; i < pos; i++) { current = current->next; } node->next = current->next; current->next = node; tList->Length++; return 0;}
获取某个位置上的结点
- 链表不为空
- 位置不小于0
- 辅助指针变量从头节点处跳到位置处
- 函数返回值为位置处的next中
LinkListNode *LinkList_Get(LinkList *list, int pos){ int i = 0; LinkListNode *current = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list == NULL || pos < 0) { return NULL; } current = &(tList->header); for (i = 0; i < pos; i++) { current = current->next; } return current->next;}
删除某位置处的结点
- 插入的反向操作····
-
- 从头结点蹦到位置处的指针
- 缓存要删除的结点的指针
接传入list的指针
list不为空,删除位置>=0,函数操作的基本
- 头指针蹦到删除位置处
- 辅助缓存指针缓存下即将删除的结点
- p->next=p->next->next 核心操作
- 原来的链表长度要减少
LinkListNode *LinkList_Delete(LinkList *list, int pos){ int i = 0; LinkListNode *current = NULL; LinkListNode *ret = NULL; TLinkList *tList = NULL; tList = (TLinkList *)list; if (list == NULL || pos < 0) { return; } current = &(tList->header); for (i = 0; i < pos; i++) { current = current->next; } ret = current->next; current->next = ret->next; tList->Length--; return ret;}
阅读全文
0 0
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- 欢迎使用CSDN-markdown编辑器
- Linux多线程——使用互斥量同步线程
- oracle数据库使用mybatis批量插入
- shell命令:暂停进程执行
- 同步、异步与阻塞、非阻塞
- HTML单选按钮(Radio)样式更改以及多选按钮(Checkbox)样式更改
- 欢迎使用CSDN-markdown编辑器
- 翻译微软官方HoloLens开发课程 语音识别
- [LeetCode] Can I Win
- 面向对象
- Mac OS Sierra (v10.12)打开任何来源的应用
- oracle11g安装与完全卸载
- odoo10 debian 8.4 Could not execute command lessc
- x264编码指南——码率控制
- Android中自动跳转到系统设置界面