数据结构与算法第三章简单数据结构new.ppt
《数据结构与算法第三章简单数据结构new.ppt》由会员分享,可在线阅读,更多相关《数据结构与算法第三章简单数据结构new.ppt(88页珍藏版)》请在课桌文档上搜索。
1、3/2/2023,1,第三章 简单数据结构,3/2/2023,2,第3章 简单数据结构,3.1 顺序表,3.2 链表,3.3 栈,3.4 队列,3.5*广义表,3/2/2023,3,线性结构的特点,存在唯一的被称为“第一个”的或“起始”的数据元素;存在唯一的被称为“最后一个”的或“终端”的数据元素;除第一个元素之外,集合中的每一个数据元素均有且仅有一个前趋;除最后一个元素之外,集合中的每一个数据元素均有且仅有一个后继。,3/2/2023,4,3.1 顺序表,3.1.1 线性表的基本概念线性表是n(n0)个数据元素的有限序列,记为:L=(a1,a2,ai,an),登记表,3/2/2023,5,线
2、性表的基本运算,初始化setnull(L),建立一个空的线性表L;求表长length(L),函数返回L中的元素个数;取第i个元素get(L,i),其中1ilength(L),否则返回NULL;求前趋prior(L,x),返回元素x的前趋;求后继next(L,x),返回元素x的后继定位locate(L,x),返回元素x在L中的位置,若x不存在,返回0或NULL;插入元素x到第i个元素之前 insert(L,x,i),其中1ilength(L)+1,否则插入失败;删除第i个元素delete(L,i),其中1ilength(L);,3/2/2023,6,3.1.2 线性表的顺序存储顺序表,顺序表:用
3、一组地址连续的存储单元依次存储线性表的元素,用数组实现,例:(A,B,C,D,E,Z),线性表的第i个元素的存储地址为Loc(ai)=Loc(a1)+(i-1)*k,3/2/2023,7,顺序表数据类型的定义,/定义每一个结点,根据具体情况变化typedef struct int yinyu;/英语 int shuxue;/数学 elemtype;/定义顺序表#define maxsize 1024typedef struct/顺序表最多容纳maxlen个元素 elemtp datamaxsize;int last;/指示当前表长 sequenlist;,英语,数学,last=5,maxlen
4、,3/2/2023,8,3.1.3 顺序表上的基本运算,(1)顺序表元素插入操作的算法:,在第i个位置插入需移动次数为n-i+1次,每个位置插入的概率为1/(n+1)平均移动次数:(n-i+1)/(n+1)=n/2(其中i=1.n+1)算法的时间复杂度 T(n)=O(n),maxsize,3/2/2023,9,3.1.3 顺序表上的基本运算,(1)顺序表元素插入操作的算法:void insert(sequenlist*L,elemtype x,int i)int j;if(i(L-last+1)printf(“插入位置不正确n”);else if(L-last=MAXSIZE)printf(“
5、表已满,发生上溢n”);else for(j=L-last;j=i;j-)L-dataj+1=L-dataj;L-datai=x;L-last=L-last+1;/*insert*/,3/2/2023,10,3.1.3 顺序表上的基本运算,(2)顺序表元素删除操作的算法:,删除第i个元素需要移动n-i次平均移动次数:(n-i)/n(其中i=0.n-1)算法的时间复杂度T(n)=O(n),3/2/2023,11,3.1.3 顺序表上的基本运算,(2)顺序表元素删除操作的算法:void delete(sequenlist*L,int i)int j;if(iL-last)printf(“删除位置不
6、正确n”);else for(j=i+1;jlast;j+)L-dataj-1=L-dataj;L-last=L-last-1;,3/2/2023,12,举例删除顺序表中的重复元素,算法思路:从顺序表中第一个元素起,逐个检查它后面是否有值相同的其它元素,若有便删除之;直到表中所有元素都已无重复元素为止。为此,算法中需设两重循环,外层控制清除的趟数,内层控制每趟的检查范围。,3/2/2023,13,举例删除顺序表中的重复元素,void Purge(sequenlist*L)int i,j,k;i=1;while(ilast)/每个元素都要比较 j=i+1;while(jlast)if(L-dat
7、aj=L-datai)/相等则删除 for(k=j+1;klast;k+)L-datak-1=L-datak;L-last=L-last-1;else j+;i+;/*Purge*/,delete(L,j),3/2/2023,14,3.2 链表,顺序表存储的缺点1)预先分配连续的空间2)不能根据需要动态分配3)插入删除等操作需要移动大量数据,3/2/2023,15,3.2 链表,单链表 循环链表 双向链表,3/2/2023,16,3.2.1单链表,单链表的组成及定义,结点组成,结点定义:typedef struct node elemtp data;struct node*next;LinkL
8、ist;,L,头指针,3/2/2023,17,3.2.1单链表,头结点,头指针,第一个结点(首元结点),第一个结点,head,头结点,头指针,3/2/2023,18,3.2.1单链表,动态生成一个结点 LinkList*H;H=(LinkList*)malloc(sizeof(LinkList);对结点中域的访问 H-elemtp和H-next 或(*H).elemtp和(*H).next释放结点占用的空间 free(H),3/2/2023,19,3.2.2单链表上的基本运算,(1)单链表建立:/尾插法建表:输入n个字符建立链表,直到输入为*结束LinkList*CreateLinkList(
9、)char ch;LinkList*head;/*head为头结点指针*/LinkList*r,*P;head=(LinkList*)malloc(sizeof(LinkList);head-next=NULL;r=head;/*尾指针初始化*/ch=getchar();while(ch!=*)/*“*”为输入数据结束符号*/P=(LinkList*)malloc(sizeof(LinkList);P-data=ch;P-next=NULL;r-next=P;r=r-next;ch=getchar();return head;,头结点,head,思考:头插法建表怎么建?,r,p,r,p,3/2
10、/2023,20,3.2.2单链表上的基本运算,(2)求表长int LengthLinkList(LinkList*L)LinkList*P=L;int j=0;While(P-next!=NULL)P=P-next;j+;return j;/*返回表长*/,头结点,head,3/2/2023,21,(3)单链表元素的查找,/查找元素为X的结点LinkList*LocateLinkList(LinkList*L,elemtyPe x;)LinkList*P;P=L-next;while(P!=NULL)/*返回找到的结点位置或NULL*/*LocateLinkList*/,3/2/2023,2
11、2,(3)单链表元素的查找,/查找第i个结点LinkList*GetLinkList(LinkList*L,int i)LinkList*P;int j=0;P=L;while(jnext!=NULL)P=P-next;j+;if(j=i)return P;else return NULL;/*GetLinkList*/,3/2/2023,23,3.2.2单链表上的基本运算,(4)单链表元素插入操作linklist_insert(linknode*L,int i,elemtp x),L,P,q=(LinkList*)malloc(sizeof(LinkList);q-data=x;q-next
12、=p-next;/修改指针 p-next=q;,q,3/2/2023,24,3.2.2单链表上的基本运算,(3)单链表元素插入操作int linklist_insert(linknode*L,int i,elemtp x)linknode*p,*q;int j=0;p=L;while(p-next!=NULL)/插入位置无效,3/2/2023,25,3.2.2单链表上的基本运算,(5)单链表元素删除操作linklist_del(linknode*L,int i),L,P,q=p-next;p-next=q-next;free(p);,3/2/2023,26,删除单链表L中的第i个结点算法,Li
13、nkList*deleteLinkList(LinkList*L,int i)LinkList*P,*S;P=getLinkList(L,i-1);/*查找第i-1个结点*/if(P=NULL)Printf(“第i-1个元素不存在,参数i 有错n”);else S=P-next;P-next=S-next;free(S);*deleteLinkList*/该算法的时间复杂度为O(n),3/2/2023,27,3.2.3循环链表和双向链表,1.循环链表,H,非空循环链表,思考:如何判断是最后一个元素?如何判断是空表?,空表,head-next=head;,3/2/2023,28,3.2.3循环链
14、表和双向链表,2.双向链表,双链表结点格式,L,格式定义:typedef struct dbnode elemtp data;struct dbnode*prior,*next;dblinknode;,空表,L,3/2/2023,29,双向链表,插入结点将S结点插入P之前,L,S-prior=P-prior;S-next=P;P-prior-next=s;P-prior=S;,p,S,3/2/2023,30,双向链表,2.删除结点思考:双向如何添加删除双链表结点,L,p-piror-next=p-next;p-next-piror=p-piror;free(p);,p,3/2/2023,31,
15、3.2.4两一元多项式相加的算法,已经两多项式A,B A=X-6X3+3X4-6X5B=1+5X3+6X5+9x6求A+B;,格式定义:typedef struct node double coef;/表示系数 int exp;/表示指数 struct node*next;polynode;,3/2/2023,32,多项式相加算法的思路,不产生新结点而利用原有结点空间,设两个指针变量p和q分别指向A和B两个多项式单链表的第一个结点,依次比较两指针所指结点的指数项。若指数相等系数相加,和不为零修改*p的系数项并删除*q,和为零删除*p和*q;若指数不等,p-expexp时*p为和多项式中的一项,
16、p-expq-exp时把*q插在*p之前(*q为和多项式中的一项);所有操作之后要相应移动指针。直到其中一个链空,把另一个链剩下的结点插在*p之后。,3/2/2023,33,3.2.4两一元多项式相加的算法,3/2/2023,34,3.3栈(stack),3.3.1栈的概念及运算栈:限制仅在一端对元素插入或删除操作的线性表,栈底,栈顶,入栈,出栈,是先进后出,后进现出的一种结构,3/2/2023,35,3.3.1栈的概念及运算,栈的基本运算:(1)置空栈 setnull(S)建立空栈S;(2)判栈空 empty(S)(3)入栈 push(S,x)将元素x压入栈S中(插入),使之成为新的栈顶元素
17、,成立的条件是栈未满;(4)出栈 pop(S)弹出栈顶元素(返回栈顶并删除),成立的条件是栈非空;(5)取栈顶元素 gettop(S)返回非空栈的栈顶元素的值;,3/2/2023,36,3.3.2 顺序栈及运算实现,顺序栈:利用顺序存储结构实现的栈,用一数组实现数据类型:typedef struct elemtp datamaxlen;int top;/栈顶指针 sqstack;,top,3/2/2023,37,3.3.2 顺序栈及运算实现,运算实现(1)顺序栈的初始化:void setnull(sqstack*S)S-top=-1;说明栈为空,Top=-1,3/2/2023,38,3.3.2
18、 顺序栈及运算实现,运算实现(2)进栈算法:int push(sqstack*S,elemtp x)if(S-top=maxlen-1)return(0);/栈已满或溢出 S-top+S-dataS-top=x;return(1);,a6,3/2/2023,39,3.3.2 顺序栈及运算实现,运算实现(3)顺序栈的元素出栈:elemtp pop(sqstack*S)if(S-top=-1)return NULL;/栈已空 else S-top-;return(S-dataS-top);,3/2/2023,40,3.3.3 链栈及运算实现,只能在链头进行操作的单链表链栈的数据类型:typedef
19、 struct node elemtp data;struct node*next;linkstack;,TOP,3/2/2023,41,3.3.3 链栈及运算实现,(1)链栈的初始化:void init_linkstack(linkstacknode*t)t=NULL;,3/2/2023,42,3.3.3 链栈及运算实现,(2)链栈的元素入栈:void push(linkstack*top,elemtp x)linkstack*p p=new linkstack;/建立新的结点 p-data=x;p-next=top;t=top;/修改栈顶指针,3/2/2023,43,3.3.3 链栈及运算
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 算法 第三 简单 new
链接地址:https://www.desk33.com/p-229802.html