数据结构 -----双链表的创建及其各功能的实现
2015-05-09 00:52
260 查看
<prename="code"class="cpp">#ifndef_DCLIST_H
#define_DCLIST_H
#include<iostream>
#include<assert.h>
usingnamespacestd;
typedefintElemType;
typedefstructNode
{
ElemTypedata;
structNode*next;
structNode*prev;
}Node;
typedefstructList
{
Node*first;
Node*last;
size_tsize;
}List;
voidInitList(List*list);
voidpush_back(List*list,ElemTypex);
voidpush_front(List*list,ElemTypex);
voidshow_list(List*list);
boolpop_back(List*list);
boolpop_front(List*list);
Node*find(List*list,ElemTypekey);
booldelete_val(List*list,ElemTypekey);
boolinsert_val(List*list,ElemTypex);
boolresver(List*list);
voiddestroy(List*list);
voidclear(List*list);
boolIsempty(List*list);
boolmodify(List*list,ElemTypex);
boollength(List*list);
voidsort(List*list);
Node*next(List*list,ElemTypex);
Node*prio(List*list,ElemTypex);
#endif
</pre><precode_snippet_id="662381"snippet_file_name="blog_20150510_2_8934957"name="code"class="cpp">#include"DCList.h"
voidInitList(List*list)
{
Node*s=(Node*)malloc(sizeof(Node));
assert(s!=NULL);
list->first=list->last=s;
list->first->prev=list->last;
list->last->next=list->first;
list->size=0;
}
voidpush_back(List*list,ElemTypex)
{
Node*s=(Node*)malloc(sizeof(Node));
assert(s!=NULL);
s->data=x;
s->prev=list->last;
//s->prev=list->first;
list->last->next=s;
list->last=s;
list->last->next=list->first;
list->first->prev=list->last;
list->size++;
}
voidpush_front(List*list,ElemTypex)
{
Node*s=(Node*)malloc(sizeof(Node));
assert(s!=NULL);
s->data=x;
s->prev=list->first;
s->next=list->first->next;
list->first->next=s;
s->next->prev=s;
if(list->size==0)
list->last=s;
list->size++;
}
voidshow_list(List*list)
{
Node*p=list->first->next;
while(p!=list->first)
{
cout<<p->data<<"-->";
p=p->next;
}
cout<<"Over!"<<endl;
}
Node*find(List*list,ElemTypekey)
{
Node*p=list->first->next;
while(p!=list->first&&p->data!=key)
p=p->next;
if(p!=list->first)
returnp;
returnNULL;
}
booldelete_val(List*list,ElemTypekey)
{
Node*q=find(list,key);
if(q==NULL)
returnfalse;
if(q==list->last)
list->last=q->prev;
q->next->prev=q->prev;
q->prev->next=q->next;
free(q);
list->size--;
returntrue;
}
boolinsert_val(List*list,ElemTypex)
{
Node*p=find(list,x);
if(p!=NULL)
returnfalse;
Node*s=(Node*)malloc(sizeof(Node));
assert(s!=NULL);
s->data=x;
p=list->first;
while(p->next!=list->first)
{
if(x<p->next->data)
break;
p=p->next;
}
s->next=p->next;
p->next->prev=s;
s->prev=p;
p->next=s;
if(p==list->last)
{
list->last=s;
}
list->size++;
returntrue;
}
boolresver(List*list)
{
Node*p=list->first->next;
Node*q=p->next;
p->next=list->first;
list->first->prev=p;
list->last=p;
while(q!=list->first)
{
p=q;
q=q->next;
p->next=list->first->next;
p->next->prev=p;
p->prev=list->first;
list->first->next=p;
}
returntrue;
}
voiddestroy(List*list)
{
clear(list);
free(list->first);
list->first=list->last=NULL;
list->size=0;
}
voidclear(List*list)
{
Node*s=list->first->next;
while(s!=list->first)
{
list->first->next=s->next;
free(s);
s=list->first->next;
}
list->last=list->first;
list->size=0;
}
boolpop_back(List*list)
{
if(Isempty(list))
{
cout<<"链表已经为空"<<endl;
returnfalse;
}
Node*s=list->last->prev;
free(list->last);
s->next=list->first;
list->last=s;
list->size--;
returntrue;
}
boolpop_front(List*list)
{
if(Isempty(list))
{
cout<<"链表已经为空"<<endl;
returnfalse;
}
Node*s=list->first->next;
list->first->next=s->next;
s->next->prev=list->first;
if(list->size==1)
{
list->last=list->first;
}
free(s);
list->size--;
returntrue;
}
boolIsempty(List*list)
{
return(list->size==0);
}
boolmodify(List*list,ElemTypex)
{
Node*s=find(list,x);
ElemTypeitem;
if(s!=NULL)
{
cout<<"请输入要替换的数:";
cin>>item;
s->data=item;
returntrue;
}
else
{
cout<<"链表中没有找到你要替换的数"<<endl;
returnfalse;
}
}
boollength(List*list)
{
Node*s=list->first->next;
intp=1;
while(s!=list->last)
{
p++;
s=s->next;
}
if(Isempty(list))
p=0;
cout<<p<<endl;
returntrue;
}
voidsort(List*list)
{
Node*s=list->first->next;
Node*p=s->next;
s->next=list->first;
list->last=s;
while(p!=list->first)
{
s=p;
p=p->next;
insert_val(list,s->data);
free(s);//调用insert_val(list,s->data)会创建结点
}
}
Node*prio(List*list,ElemTypex)
{
Node*s=find(list,x);
if(s!=NULL)
{
if(s==list->first->next)
{
cout<<"没有前驱!"<<endl;
}
else
{
returns->prev;
}
}
else
{
cout<<"没有找到这个数!"<<endl;
returnNULL;
}
}
Node*next(List*list,ElemTypex)
{
Node*s=find(list,x);
if(s!=NULL)
{
if(s==list->last)
{
cout<<"没有后继"<<endl;
}
else
{
returns->next;
}
}
else
{
cout<<"没有找到要查找的数"<<endl;
returnNULL;
}
}
#include"DCList.h"
voidmain()
{
Listmylist;
InitList(&mylist);
intselect=1;
ElemTypeitem;
Node*p=NULL;
intpos;
Node*s;
while(select)
{
cout<<"**********DCList*******************"<<endl;
cout<<"******hello!menu***********"<<endl;
cout<<"*[0]quit_system[1]push_back*"<<endl;
cout<<"*[2]push_front[3]show_seqlist*"<<endl;
cout<<"*[4]pop_back[5]pop_front*"<<endl;
cout<<"*[6]length[7]insert_val*"<<endl;
cout<<"*[8]sort[9]delete_val*"<<endl;
cout<<"*[10]find[11]prio*"<<endl;
cout<<"*[12]modify[13]clear*"<<endl;
cout<<"*[14]destroy[15]next*"<<endl;
cout<<"*[16]resver*"<<endl;
cout<<"******************over**********"<<endl;
cout<<"请选择:>";
cin>>select;
switch(select)
{
case1:
cout<<"请输入要插入的数据(-1结束):>";
while(cin>>item,item!=-1)
{
push_back(&mylist,item);
}
break;
case2:
cout<<"请输入要插入的数据(-1结束):>";
while(cin>>item,item!=-1)
{
push_front(&mylist,item);
}
break;
case3:
show_list(&mylist);
break;
case4:
pop_back(&mylist);
break;
case5:
pop_front(&mylist);
break;
case6:
length(&mylist);
break;
case7:
cout<<"请输入要插入的数据:";
cin>>item;
insert_val(&mylist,item);
break;
case8:
sort(&mylist);
break;
case9:
cout<<"请输入要插删除的值:>";
cin>>item;
delete_val(&mylist,item);
break;
case10:
cout<<"请输入要查找的值:>";
cin>>item;
p=find(&mylist,item);
if(find(&mylist,item)!=NULL)
cout<<"已找到"<<endl;
else
cout<<"未找到:"<<endl;
break;
case11:
cout<<"请输入要查找前驱的数:>";
cin>>item;
s=prio(&mylist,item);
if(s!=NULL)
cout<<"它的前驱是:"<<s->data<<endl;
break;
case12:
cout<<"请输入要修改的值:>";
cin>>item;
modify(&mylist,item);
break;
case13:
clear(&mylist);
break;
case14:
destroy(&mylist);
break;
case15:
cout<<"请输入要查找后继的数:>";
cin>>item;
s=next(&mylist,item);
if(s!=NULL)
cout<<"它的后继是:"<<s->data<<endl;
break;
case16:
resver(&mylist);
break;
default:
break;
}
}
}
相关文章推荐
- 数据结构:线性表(顺序存储)顺序栈类(实现创建,输出,入栈出栈,读栈顶元素功能)
- 双链表的实现及其功能大全!!!
- 数据结构:线性表(顺序存储)顺序表类(实现顺序表的创建,输出,插入,删除功能)
- mongoose创建数据结构,实现基本增删改查功能
- C#语言实现创建、删除和移动文件夹及其文件夹列表功能
- 数据结构:java创建串并实现增删改查功能
- JAVA数据结构 线性表的链式存储及其实现
- Setvlet(补充)(理论、创建、实现方式、功能)
- 实验 9-1 1. 实现以下功能 a) 调用 pipe()创建无名管道 b) 调用 fork 创建一个子进程 c) 在子进程中向管道内写入 128k 数据,打印出进程号及成功写入的字节数 d) 在父
- 【Android SDK开发】各种Android Dialog创建及其监听事件实现
- 创建一个宏,实现通过excel导出TXT文本功能
- 创建通讯录实现(增,删,查,改,显示,清空)功能
- CMAP原理及其在MFC中的实现(MAP模板没有顺序遍历的功能)
- 浅述节点的创建及常见功能的实现
- 表达式树及其变体,以及我是如何借着个原理实现简易计算器的功能的
- QT中如何实现XML文件的创建、增加、修改、删除功能。
- objective-c 结构体单链表的实现,创建插入删除功能
- C++ 版数据结构实现顺序表的各种功能
- C#使用双链表来实现模拟IE前进后退功能
- 数据结构--单链表基本功能实现程序…