数据结构:单向循环链表
温馨提示:这篇文章已超过384天没有更新,请注意相关的内容是否还可用!
功能:
1.创建头节点
loop_p creat_head(){
loop_p L=(loop_p)malloc(sizeof(loop_list));
if(L==NULL){
printf("空间申请失败\n");
return NULL;
}
L->len=0;
L->next=L;
return L;
}
2.创建节点
//创建节点
loop_p creat_node(int data){
//在堆区申请一个节点的空间
loop_p new=(loop_p)malloc(sizeof(loop_list));
if(new==NULL){
printf("空间申请失败\n");
return NULL;
}
new->data=data;
return new;//返回申请的节点的首地址
}
3.判空
//判空
int loop_empty(loop_p H){
if(H==NULL){
printf("头节点为空\n");
return -1;
}
//如果头节点指向头节点本身说明链表空
return H->next==H?1:0;
}
4.头插
//头插
void insert_head(loop_p H,int data){
if(H==NULL){
printf("头节点为空\n");
return;
}
loop_p new=creat_node(data);
new->next=H->next;
H->next=new;
H->len++;
}
5.尾插
//尾插
void insert_tail(loop_p H,int data){
if(H==NULL){
printf("头节点为空\n");
return;
}
loop_p new=creat_node(data);
loop_p p=H;
while(p->next!=H){
p=p->next;
}
new->next=H;
p->next=new;
H->len++;
}
6.按位置插入
//按位置插入,头节点是第0个节点
void insert_pos(loop_p H,int pos,int data){
if(H==NULL){
printf("头节点为空\n");
return;
}
loop_p p=H;
//判断位置合理性
if(posH->len+1){
printf("位置不合理\n");
return;
}
for(int i=0;inext;
}
loop_p new=creat_node(data);
new->next=p->next;
p->next=new;
new->data=data;
H->len++;
}
7.尾删
//尾删
void del_tail(loop_p H){
if(H==NULL){
printf("头节点为空\n");
return;
}
if(loop_empty(H)){
printf("链表为空\n");
return;
}
loop_p p=H;
while(p->next->next!=H)
p=p->next;
loop_p del=p->next;
p->next=p->next->next;
free(del);
H->len--;
}
8.头删
//头删
void del_head(loop_p H){
if(H==NULL){
printf("头节点为空\n");
return;
}
if(loop_empty(H)){
printf("链表为空\n");
return;
}
loop_p p=H;
loop_p del=p->next;
p->next=p->next->next;
free(del);
H->len--;
}
9.按位置删除
//按位置删除
void del_pos(loop_p H,int pos){
if(H==NULL){
printf("头节点为空\n");
return;
}
if(loop_empty(H)){
printf("链表为空\n");
return;
}
//判断位置合理性
if(posH->len+1){
printf("位置不合理\n");
return;
}
loop_p p=H;
for(int i=1;inext;
}
loop_p del=p->next;
p->next=p->next->next;
free(del);
H->len--;
}
10.打印列表
//打印列表
void out_put(loop_p H){
if(H==NULL){
printf("头节点为空\n");
return;
}
loop_p p=H->next;
while(p!=H){
printf("%d ",p->data);
p=p->next;
}
putchar(10);
}
11.按值查找,返回在链表中的位置
int search_value(loop_p H,int data){
if(H==NULL){
printf("头节点为空\n");
return -1;
}
loop_p p=H->next;
int i=1;
while(p->next!=H){
if(p->data==data){
return i;
}
p=p->next;
i++;
}
printf("查找失败\n");
}
12.按下标查找,返回数值
int search_pos(loop_p H,int pos){
if(H==NULL){
printf("头节点为空\n");
return -1;
}
//判断位置合理性
if(posH->len){
printf("位置不合理\n");
return -1;
}
loop_p p=H->next;
for(int i=1;inext;
}
return p->data;
}
13.按值修改元素
void updata_value(loop_p H,int data,int new_data){
if(H==NULL){
printf("头节点为空\n");
return;
}
loop_p p=H->next;
while(p!=H){
if(p->data==data)
p->data=new_data;
p=p->next;
}
printf("查找不到该元素\n");
}
14.循环链表逆置
//循环链表逆置
void overturn_loop(loop_p H){
if(H==NULL){
printf("头节点为空\n");
return;
}
if(loop_empty(H)){
printf("链表为空\n");
return;
}
if(H->next->next==H){
printf("只有一个元素,不用逆置\n");
return;
}
loop_p p=H->next->next;
H->next->next=H;
loop_p q=p->next;
while(p!=H){
p->next=H->next;
H->next=p;
p=q;
if(q!=H)
q=q->next;
}
}
#ifndef _LOOP_LIST_H__
#define _LOOP_LIST_H__
#include
#include
#include
typedef struct loop_list{
union{
int len;
int data;
};
struct loop_list *next;
}loop_list,*loop_p;
//创建单向循环链表
loop_p creat_head();
//创建节点
loop_p creat_node(int data);
//判空
int loop_empty(loop_p H);
//头插
void insert_head(loop_p H,int data);
//打印列表
void out_put(loop_p H);
//尾插
void insert_tail(loop_p H,int data);
//按位置插入,头节点是第0个节点
void insert_pos(loop_p H,int pos,int data);
//头删
void del_tail(loop_p H);
//尾删
void del_head(loop_p H);
//按位置删除
void del_pos(loop_p H,int data);
//按值查找,返回在链表中的位置
int search_value(loop_p H,int data);
//按下标查找,返回数值
int search_pos(loop_p H,int pos);
//按值修改元素
void updata_value(loop_p H,int data,int new_data);
//循环链表逆置
void overturn_loop(loop_p H);
#endif
(图片来源网络,侵删)
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
