C语言(链表)探索.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
链表 链表 动态数据结构 自引用的结构体 动态内存分配 链表 程序设计举例 动态数据结构 Dynamic data structures(动态数据结构) 在程序的执行过程中可以增长和缩短的数据结构。 Linked lists(链表) 在任何地方进行插入和删除。 Stacks(栈) 在栈的顶端进行插入和删除。 Queues(对列) 在队列的末尾删除,在队列的前面插入。 自引用的结构体 自引用的结构体 包含指向相同结构类型的指针成员 可以链接到一起,构成有用的数据结构: 链表 栈 队列 树 动态内存分配 动态内存分配 在程序执行期间获取或释放内存 相关的函数(stdlib.h) malloc() free() 相关的运算符 sizeof 动态内存分配 malloc()函数 void* malloc(size_t size) 参数size :表示要分配的内存的字节数 size_t为sizeof返回的整数类型 一般用 sizeof 运算符确定对象的大小 返回值:指向分配内存的 void* 类型的指针 void* 类型的指针可以被赋值给任何类型的指针变量 如果没有可用内存,则返回 NULL 动态内存分配 free()函数 void free(void* aPtr) 释放aPtr指向的内存空间 aPtr指向的应该是用 malloc 分配的内存空间 如果不调用free释放array指向的空间,则程序结束后array消失了,但其所指的该段内存仍旧存在且不能被使用(其地址丢失了),即出现内存泄露。 链表 链表 用指针链接的自引用结构的线性集合,这些结构称为结点。 通过指向链表的第一个结点的指针访问链表。 后续的结点通过存储在每个结点中的链接指针成员来访问。 链表中最后一个结点的链接指针被设置为NULL,以标志链表的结尾。 什么时候用链表替代数组 数据成员的数目无法事先确定。 对数据进行快速的排序。 案例分析:链表 链表 问题 输入任意个整数创建链表。 实现常用的操作:遍历,插入,删除,空表判断。 实现(cw1311.c) 案例分析:链表 链表 实现 案例分析:链表 链表 实现 案例分析:链表 链表 实现 案例分析:链表 链表 实现 案例分析:链表 链表 实现 案例分析:链表 链表 实现 案例分析:链表 链表 插入结点的函数 案例分析:链表 链表 插入结点的函数 案例分析:链表 链表 插入结点的函数 案例分析:链表 链表 删除结点的函数 案例分析:链表 链表 删除结点的函数 案例分析:链表 链表 删除结点的函数 案例分析:链表 链表 判空和输出链表的函数 小结 动态数据结构 自引用的结构体 动态内存分配 链表 链表 struct node { int data; struct node *nextPtr; }; 20 42 数据成员 指针 结点(node) 空指针 链 头指针 int *array, n=30; array = (int*)malloc(n*sizeof(int)); struct node *sPtr; sPtr = malloc(sizeof(struct node)); int *array, n=30; array = (int*)malloc(n*sizeof(int)); … free(array); 20 35 42 #include stdio.h #include stdlib.h struct listNode { int data; struct listNode *nextPtr; }; typedef struct listNode ListNode; typedef ListNode* ListNodePtr; void insert(ListNodePtr*, int); int delete(ListNodePtr*, int); int isEmpty(ListNodePtr); void printList(ListNodePtr); void menu(void); void menu(void) { printf(Enter your choice:\n 1 to insert an element into the list.\n 2 to delete an element from the list.\n 3 to ent.\n); } void main() { ListNodePtr listPtr = NULL; int choice; int item; menu(); printf(? ); scanf(%d, choice); while (c

文档评论(0)

***** + 关注
实名认证
内容提供者

我是自由职业者,从事文档的创作工作。

1亿VIP精品文档

相关文档