第四周项目5-循环双链表应用
来源:互联网 发布:犀牛软件安装失败 编辑:程序博客网 时间:2024/06/08 15:24
问题及代码:
/* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:项目5.cpp * 作 者:董雪 * 完成日期:2016年9月22日 * 版 本 号:v1.0 *问题描述:设非空线性表ha和hb都用带头节点的循环双链表表示。设计一个算法Insert(ha,hb,i)。 其功能是:i=0时,将线性表hb插入到线性表ha的最前面;当i>0时,将线性表hb插入到 线性表ha中第i个节点的后面;当i大于等于线性表ha的长度时,将线性表hb插入到线性表ha的最后面。 *输入描述:无。 *程序输出:新链表。 */ 1.头文件:cdlinklist.h,包含定义双链表数据结构的代码、宏定义、要实现算法的函数的声明;<pre class="prettyprint"><code class=" hljs vala"><span class="hljs-preprocessor">#ifndef CDLINKLIST_H_INCLUDED</span><span class="hljs-preprocessor">#define CDLINKLIST_H_INCLUDED</span><span class="hljs-comment">//循环双链表基本运算函数</span>typedef <span class="hljs-keyword">int</span> ElemType;typedef <span class="hljs-keyword">struct</span> DNode <span class="hljs-comment">//定义双链表结点类型</span>{ ElemType data; <span class="hljs-keyword">struct</span> DNode *prior; <span class="hljs-comment">//指向前驱结点</span> <span class="hljs-keyword">struct</span> DNode *next; <span class="hljs-comment">//指向后继结点</span>} CDLinkList;<span class="hljs-keyword">void</span> CreateListF(CDLinkList *&L,ElemType a[],<span class="hljs-keyword">int</span> n); <span class="hljs-comment">//头插法建立循环双链表</span><span class="hljs-keyword">void</span> CreateListR(CDLinkList *&L,ElemType a[],<span class="hljs-keyword">int</span> n); <span class="hljs-comment">//尾插法建立循环双链表</span><span class="hljs-keyword">void</span> InitList(CDLinkList *&L); <span class="hljs-comment">//初始化循环双链表</span><span class="hljs-keyword">void</span> DestroyList(CDLinkList *&L); <span class="hljs-comment">//销毁</span><span class="hljs-keyword">bool</span> ListEmpty(CDLinkList *L); <span class="hljs-comment">//判断是否为空</span><span class="hljs-keyword">int</span> ListLength(CDLinkList *L); <span class="hljs-comment">//求链表长度</span><span class="hljs-keyword">void</span> DispList(CDLinkList *L); <span class="hljs-comment">//输出链表</span><span class="hljs-keyword">bool</span> GetElem(CDLinkList *L,<span class="hljs-keyword">int</span> i,ElemType &e); <span class="hljs-comment">//取链表元素</span><span class="hljs-keyword">int</span> LocateElem(CDLinkList *L,ElemType e); <span class="hljs-comment">//查找元素</span><span class="hljs-keyword">bool</span> ListInsert(CDLinkList *&L,<span class="hljs-keyword">int</span> i,ElemType e); <span class="hljs-comment">//插入节点</span><span class="hljs-keyword">bool</span> ListDelete(CDLinkList *&L,<span class="hljs-keyword">int</span> i,ElemType &e); <span class="hljs-comment">//删除节点</span>2.源文件:cdlinklist.cpp,包含实现各种算法的函数的定义</code><pre class="prettyprint"><code class=" hljs cpp"><span class="hljs-comment">//循环双链表基本运算函数</span><span class="hljs-preprocessor">#include <stdio.h></span><span class="hljs-preprocessor">#include <malloc.h></span><span class="hljs-preprocessor">#include "cdlinklist.h"</span><span class="hljs-keyword">void</span> CreateListF(CDLinkList *&L,ElemType a[],<span class="hljs-keyword">int</span> n) <span class="hljs-comment">//头插法建立循环双链表</span>{ CDLinkList *s; <span class="hljs-keyword">int</span> i; L=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建头结点</span> L->next=NULL; <span class="hljs-keyword">for</span> (i=<span class="hljs-number">0</span>; i<n; i++) { s=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList));<span class="hljs-comment">//创建新结点</span> s->data=a[i]; s->next=L->next; <span class="hljs-comment">//将*s插在原开始结点之前,头结点之后</span> <span class="hljs-keyword">if</span> (L->next!=NULL) L->next->prior=s; L->next=s; s->prior=L; } s=L->next; <span class="hljs-keyword">while</span> (s->next!=NULL) <span class="hljs-comment">//查找尾结点,由s指向它</span> s=s->next; s->next=L; <span class="hljs-comment">//尾结点next域指向头结点</span> L->prior=s; <span class="hljs-comment">//头结点的prior域指向尾结点</span>}<span class="hljs-keyword">void</span> CreateListR(CDLinkList *&L,ElemType a[],<span class="hljs-keyword">int</span> n) <span class="hljs-comment">//尾插法建立循环双链表</span>{ CDLinkList *s,*r; <span class="hljs-keyword">int</span> i; L=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建头结点</span> L->next=NULL; r=L; <span class="hljs-comment">//r始终指向尾结点,开始时指向头结点</span> <span class="hljs-keyword">for</span> (i=<span class="hljs-number">0</span>; i<n; i++) { s=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList));<span class="hljs-comment">//创建新结点</span> s->data=a[i]; r->next=s; s->prior=r; <span class="hljs-comment">//将*s插入*r之后</span> r=s; } r->next=L; <span class="hljs-comment">//尾结点next域指向头结点</span> L->prior=r; <span class="hljs-comment">//头结点的prior域指向尾结点</span>}<span class="hljs-keyword">void</span> InitList(CDLinkList *&L) <span class="hljs-comment">//初始化循环双链表</span>{ L=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建头结点</span> L->prior=L->next=L;}<span class="hljs-keyword">void</span> DestroyList(CDLinkList *&L) <span class="hljs-comment">//销毁</span>{ CDLinkList *p=L,*q=p->next; <span class="hljs-keyword">while</span> (q!=L) { <span class="hljs-built_in">free</span>(p); p=q; q=p->next; } <span class="hljs-built_in">free</span>(p);}<span class="hljs-keyword">bool</span> ListEmpty(CDLinkList *L) <span class="hljs-comment">//判断是否为空</span>{ <span class="hljs-keyword">return</span>(L->next==L);}<span class="hljs-keyword">int</span> ListLength(CDLinkList *L) <span class="hljs-comment">//求链表长度</span>{ CDLinkList *p=L; <span class="hljs-keyword">int</span> i=<span class="hljs-number">0</span>; <span class="hljs-keyword">while</span> (p->next!=L) { i++; p=p->next; } <span class="hljs-keyword">return</span>(i);}<span class="hljs-keyword">void</span> DispList(CDLinkList *L) <span class="hljs-comment">//输出链表</span>{ CDLinkList *p=L->next; <span class="hljs-keyword">while</span> (p!=L) { <span class="hljs-built_in">printf</span>(<span class="hljs-string">"%d "</span>,p->data); p=p->next; } <span class="hljs-built_in">printf</span>(<span class="hljs-string">"\n"</span>);}<span class="hljs-keyword">bool</span> GetElem(CDLinkList *L,<span class="hljs-keyword">int</span> i,ElemType &e) <span class="hljs-comment">//取链表元素</span>{ <span class="hljs-keyword">int</span> j=<span class="hljs-number">0</span>; CDLinkList *p; <span class="hljs-keyword">if</span> (L->next!=L) <span class="hljs-comment">//双链表不为空表时</span> { <span class="hljs-keyword">if</span> (i==<span class="hljs-number">1</span>) { e=L->next->data; <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } <span class="hljs-keyword">else</span> <span class="hljs-comment">//i不为1时</span> { p=L->next; <span class="hljs-keyword">while</span> (j<i-<span class="hljs-number">1</span> && p!=L) { j++; p=p->next; } <span class="hljs-keyword">if</span> (p==L) <span class="hljs-keyword">return</span> <span class="hljs-keyword">false</span>; <span class="hljs-keyword">else</span> { e=p->data; <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } } } <span class="hljs-keyword">else</span> <span class="hljs-comment">//双链表为空表时</span> <span class="hljs-keyword">return</span> <span class="hljs-number">0</span>;}<span class="hljs-keyword">int</span> LocateElem(CDLinkList *L,ElemType e) <span class="hljs-comment">//查找元素</span>{ <span class="hljs-keyword">int</span> n=<span class="hljs-number">1</span>; CDLinkList *p=L->next; <span class="hljs-keyword">while</span> (p!=NULL && p->data!=e) { n++; p=p->next; } <span class="hljs-keyword">if</span> (p==NULL) <span class="hljs-keyword">return</span>(<span class="hljs-number">0</span>); <span class="hljs-keyword">else</span> <span class="hljs-keyword">return</span>(n);}<span class="hljs-keyword">bool</span> ListInsert(CDLinkList *&L,<span class="hljs-keyword">int</span> i,ElemType e) <span class="hljs-comment">//插入节点</span>{ <span class="hljs-keyword">int</span> j=<span class="hljs-number">0</span>; CDLinkList *p=L,*s; <span class="hljs-keyword">if</span> (p->next==L) <span class="hljs-comment">//原双链表为空表时</span> { s=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建新结点*s</span> s->data=e; p->next=s; s->next=p; p->prior=s; s->prior=p; <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } <span class="hljs-keyword">else</span> <span class="hljs-keyword">if</span> (i==<span class="hljs-number">1</span>) <span class="hljs-comment">//原双链表不为空表但i=1时</span> { s=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建新结点*s</span> s->data=e; s->next=p->next; p->next=s; <span class="hljs-comment">//将*s插入到*p之后</span> s->next->prior=s; s->prior=p; <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } <span class="hljs-keyword">else</span> { p=L->next; <span class="hljs-keyword">while</span> (j<i-<span class="hljs-number">2</span> && p!=L) { j++; p=p->next; } <span class="hljs-keyword">if</span> (p==L) <span class="hljs-comment">//未找到第i-1个结点</span> <span class="hljs-keyword">return</span> <span class="hljs-keyword">false</span>; <span class="hljs-keyword">else</span> <span class="hljs-comment">//找到第i-1个结点*p</span> { s=(CDLinkList *)<span class="hljs-built_in">malloc</span>(<span class="hljs-keyword">sizeof</span>(CDLinkList)); <span class="hljs-comment">//创建新结点*s</span> s->data=e; s->next=p->next; <span class="hljs-comment">//将*s插入到*p之后</span> <span class="hljs-keyword">if</span> (p->next!=NULL) p->next->prior=s; s->prior=p; p->next=s; <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } }}<span class="hljs-keyword">bool</span> ListDelete(CDLinkList *&L,<span class="hljs-keyword">int</span> i,ElemType &e) <span class="hljs-comment">//删除节点</span>{ <span class="hljs-keyword">int</span> j=<span class="hljs-number">0</span>; CDLinkList *p=L,*q; <span class="hljs-keyword">if</span> (p->next!=L) <span class="hljs-comment">//原双链表不为空表时</span> { <span class="hljs-keyword">if</span> (i==<span class="hljs-number">1</span>) <span class="hljs-comment">//i==1时</span> { q=L->next; <span class="hljs-comment">//删除第1个结点</span> e=q->data; L->next=q->next; q->next->prior=L; <span class="hljs-built_in">free</span>(q); <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } <span class="hljs-keyword">else</span> <span class="hljs-comment">//i不为1时</span> { p=L->next; <span class="hljs-keyword">while</span> (j<i-<span class="hljs-number">2</span> && p!=NULL) { j++; p=p->next; } <span class="hljs-keyword">if</span> (p==NULL) <span class="hljs-comment">//未找到第i-1个结点</span> <span class="hljs-keyword">return</span> <span class="hljs-keyword">false</span>; <span class="hljs-keyword">else</span> <span class="hljs-comment">//找到第i-1个结点*p</span> { q=p->next; <span class="hljs-comment">//q指向要删除的结点</span> <span class="hljs-keyword">if</span> (q==NULL) <span class="hljs-keyword">return</span> <span class="hljs-number">0</span>; <span class="hljs-comment">//不存在第i个结点</span> e=q->data; p->next=q->next; <span class="hljs-comment">//从单链表中删除*q结点</span> <span class="hljs-keyword">if</span> (p->next!=NULL) p->next->prior=p; <span class="hljs-built_in">free</span>(q); <span class="hljs-comment">//释放*q结点</span> <span class="hljs-keyword">return</span> <span class="hljs-keyword">true</span>; } } } <span class="hljs-keyword">else</span> <span class="hljs-keyword">return</span> <span class="hljs-keyword">false</span>; <span class="hljs-comment">//原双链表为空表时</span>}</code>
源文件 main.cpp
#include "dlinklist.h" void Insert(CDLinkList *&ha, CDLinkList *&hb,int i) { CDLinkList *p=ha->next,*q; int lena=1,j=1; while (p->next!=ha) //求出ha的长度lena { lena++; p=p->next; } if (i==0) //将hb的所有数据结点插入到ha的头结点和第1个数据结点之间 { p=hb->prior; //p指向hb的最后一个结点/ p->next=ha->next; //将*p链到ha的第1个数据结点前面 ha->next->prior=p; ha->next=hb->next; hb->next->prior=ha; //将ha头结点与hb的第1个数据结点链起来 } else if (i<lena) //将hb插入到ha中间 { p=ha->next; while (j<i) //在ha中查找第i个结点*p { j++; p=p->next; } q=p->next; //q指向*p结点的后继结点/ p->next=hb->next; //hb->prior指向hb的最后一个结点 hb->next->prior=p; hb->prior->next=q; q->prior=hb->prior; } else //将hb链到ha之后 { ha->prior->next=hb->next; //ha->prior指向ha的最后一个结点 hb->next->prior=ha->prior; hb->prior->next=ha; ha->prior=hb->prior; } free(hb); //释放hb头结点 } int main() { CDLinkList *HA, *HB; ElemType ha[]= {0, 1, 2, 3, 4, 5, 6, 7 ,8, 9}; InitList(HA); CreateListF(HA, ha, 10); ElemType hb[]= {100, 200, 300, 400, 500}; InitList(HB); CreateListF(HB, hb, 5); printf("HA: "); DispList(HA); printf("HB: "); DispList(HB); Insert(HA, HB, 0); //将0改为其他值,多次运行程序完成测试 printf("new HA: "); DispList(HA); DestroyList(HA); return 0; }
<code class=" hljs vala"><code class=" hljs cpp">运行结果截图:<img src="http://img.blog.csdn.net/20160922105152540?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" /></code></code><pre class="prettyprint">
知识点总结:双链表算法库采用程序的多文件组织形式。
学习心得:不是很理解。
0 0
- 第四周【项目5- 循环双链表应用】
- 第四周项目5 循环双链表应用
- 第四周项目5循环双链表应用
- 第四周项目5-循环双链表应用
- 第四周项目5-循环双链表应用
- 第四周项目5-循环双链表应用
- 第四周项目5-循环双链表应用
- 第四周项目5-循环双链表应用 .
- 第四周 项目5- 循环双链表应用
- 第四周 项目5- 循环双链表应用
- 第四周 项目5- 循环双链表应用
- 第四周项目5-循环双链表应用
- 第四周 项目5- 循环双链表应用
- 第四周 【项目5- 循环双链表应用】
- (第四周项目6)循环双链表应用
- 第四周项目7- 循环双链表应用
- 第四周【项目6- 循环双链表应用】
- 数据结构第四周项目-循环双链表应用
- 第四周项目2-建设“单链表”算法库
- (第四周项目4)建设双链表算法库
- 第四周-项目二-建立“单链表”算法库
- MT6323 PMIC 功能介绍
- 长方形面积
- 第四周项目5-循环双链表应用
- jquery获取URL参数
- RecyclerView+MaterialRefreshLayout
- 正则表达式基本语法
- js ajax提交后按钮显示loading简单效果
- 第4周项目3-单链表应用(1)
- 第四周任务—输出矩形的周长和面积
- 直播技术(从服务端到客户端)二
- c#识别图片验证码