- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构CC循环链表
例3.1 有一个单链表L(至少有一个结点),其头结点指针为head,编写一个函数将L逆置,即最后一个结点变成第1个结点,原来倒数第二个结点变成第二个结点……如此等等。 解:本题采用的算法是,从头到尾遍历单链表L,并设置3个附加指针p、q、r,p指向当前处理的结点,q指向p的下一个结点,r指向q的下一个结点,q、r的作用是为了防止倒置指针时,下一个结点的丢失而设置的,有了这三个指针,就可以方便地实现指针的倒置。最后将第一个结点的next域置为NULL,并将头指针指向最后一个结点,这样达到了本题的要求。 void invert( linklist head) { linklist p, q, r; p=head; q=p-next; while(q!=NULL) /*没有后继时停止*/ { r=q-next; q-next=p; p=q; q=r; } head-next=NULL; head=p; } 堆栈的最简单的表示方法是采用一维数组,为形象起见,一般在图中将堆栈画成竖直的 。 设数组名为data,其下标的下界为0,上界为n。 一般需用一个变量top记录当前栈顶的下标值,top也叫做栈指针。 二、堆栈的运算 入栈(push) 入栈的主要操作是先将栈顶指 针加1;然后将入栈元素放到栈 顶指针所指示下值的位置上。 设用指针P表示堆栈,入栈的元 素值为x,则可得到入栈函数如 下: #define N 30 Typedef struct stack {datatype data[ N ]; Int top; }sqstack; void pop (sqstack *p) { if (p-top== -1) printf(“空栈!\n”); /*栈为空显示相应的信息*/ else { x=p-data[p-top]; ( p- top)--; /*栈顶位置下移*/ } return x; } 链堆栈是栈的链接存储表示,它是只允许在表头进行插入和删除运算的单链表。 它与普通的单链表没有什么不同,只是将头指针head改称为栈顶指针top。 链堆栈的入栈算法 在栈顶指针是top的链堆栈中插入一个值为x的结点的算法: void push (linklist top, datatype x) { linklist s; s=new node ; /*建立一个结点指针*/ s-data=x; s-next=top; top=s; } int pop(linklist top) { int x; linklist p; if( top= = NULL) cout“栈为空!” ; else {x=top-data; p=top; top=top-next; delete p; return x; } } 3.3 循环链表与双向链表 循环链表(circular linked list)是一种首尾相接的链表,将单链表表尾结点原来的空指针改为指向表头结点,就成为循环链表。 循环链表并不多占存储单元,但从循环链表的任一个结点出发都可以访问到此链表的每一个结点,因为当访问到表尾结点后又能返回到头结点。 例3.2 有两个循环单链表,头指针分为head1和head2,编写函数将链表head2链接到链表head1之后,链接后的链表仍保持是循环链表的形式。 解:先分别找到两个链表的表尾,将head2放入链表head1的表尾,将两个链表链接起来,然后将head1放入原head2链表的表尾,构成新的循环链表。 例3.2算法 link(linklist head1,head2) { linklist p, q; p=head1; while(p-next!=head1) p=p-
您可能关注的文档
最近下载
- 2024年9月8日贵州省黔西南州州直遴选(事业单位考聘)笔试真题及答案解析.doc VIP
- 电缆敷设施工方案及安全措施完整.docx VIP
- 推荐系统之图神经网络推荐算法:Graph Collaborative Filtering:LightGCN算法深度解析.docx VIP
- 城区生态廊道可行性研究报告.docx
- 兴业证券-宏观策略-研究框架培训:资金面研究框架.pdf VIP
- 《现代食品原料学》第10章 水与食品原料的检验和标准.pptx VIP
- 小学数学四年级上册角度量测试题.docx VIP
- 1.2技术的性质(课件)-高中通用技术必修技术与设计1人教版.pptx VIP
- 改善铝蚀刻工艺腐蚀缺陷的方法及装置.pdf VIP
- HG_T 5959-2021 生化法处理废(污)水用碳源 乙酸钠.docx VIP
文档评论(0)