严蔚敏数据结构讲义(第02章 线性表).doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
线性表 本章知识结构: 线性表的特点: 有唯一的头; 唯一的尾; 除头外都有一个直接前驱; 除尾外都有一个直接后继。 线性表的类型定义 线性表是n(n=0)个数据元素的有限序列——有限个元素;元素之间有次序。 长度:表中元素的个数。 存储容量:整个线性表所占的空间。 位序:元素所在位置的序号,即第几个。 线性表的基本操作:1.访问(元素查询,定位);2.插入元素;3.删除元素。 线性表的抽象数据类型定义(三元法定义)ADT List{数据对象;数据关系;基本操作} 顺序表(sequence)——线性表的顺序表示与实现 特点: 逻辑地址相邻,物理地址也相邻; 优点:可随机访问; 缺点:插入、删除不方便。 实现:一维数组 C语言知识复习 typedef int DataType;给整型int定义一个别名DataType,之后就可以使用DataType定义整型变量了,例如: DataType x,y=8; 结构体类型的定义 struct card{int num; char name[20]; ……}——定义了一个结构体card 结构体变量的定义 struct card stu1,stu2;——其中struct card是一个整体,表示结构体类型名 给结构体类型名定义别名 typedef struct card DataType;给结构体struct card定义一个别名DataType 给匿名结构体定义别名 typedef struct {int month; int day; int year;} Date; //该结构体为匿名结构体,相当于类的匿名对象。即该结构体无名称,只有别名 class PC; new PC().action(); //匿名对象的使用 sizeof函数: 返回一个对象或者类型所占的内存字节数。……} *LinkList; //声明LinkList为struct node类型的指针 malloc函数和free函数 —— memory allocation内存分配 1. 函数原型及说明: void *malloc(long NumBytes):该函数分配了NumBytes个字节,并返回了指向这块内存的指针。如果分配失败,则返回一个空指针(NULL)。关于分配失败的原因,应该有多种,比如说空间不足就是一种。 void free(void *FirstByte): 该函数是将之前用malloc分配的空间还给程序或者是操作系统,也就是释放了这块内存,让它重新得到自由。函数: char *Ptr = NULL; Ptr = (char *)malloc(100 * sizeof(char)); //malloc()函数的类型是(void *),任何类型的指针都可以转换成(void *),但是最好还是在前面进行强制类型转换功能: 在内存的动态存储区中分配n个长度为size的连续空间,函数返回一个指向分配起始地址的指针;如果分配不成功,返回NULL。   跟malloc的区别:   calloc在动态分配完内存后,自动初始化该内存空间为零,而malloc不初始化,里边数据是随机的垃圾数据。原型:extern void *realloc(void *mem_address, unsigned int newsize); 语法:指针名=(数据类型*)realloc(要改变内存大小的指针名,新的大小)。 头文件:#include stdlib.h 有些编译器需要#include alloc.h,在TC2.0中可用alloc.h头文件 功能:先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域,同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。 返回值:如果重新分配成功则返回指向被分配内存的指针,否则返回空指针NULL。  注意:这里原始内存中的数据还是保持不变的。当内存不再使用时,应使用free()函数将内存块释放。ListLink HeadInsertCreateList() //头插法创建单链表 { ListLink head,s; char ch; head=NULL; printf(Please input character(#-stop).\n); ch=getchar(); while(ch!=#) { s =(ListLink)malloc(sizeof(ListNode)); //申请空间 s-data = ch; //结点数据域赋值 s-next = head;

文档评论(0)

白领文档(原创) + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档