- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)