loop_list单向循环列表

#include "loop_list.h"

//创建单向循环链表

loop_p create_head()

{

loop_p L=(loop_p)malloc(sizeof(loop_list));

if(L==NULL)

{

printf("create fail\n");

return NULL;

}

L->len = 0;

L->next=L;

return L;

}

//创建节点

loop_p create_node(datatype data)

{

loop_p new=(loop_p)malloc(sizeof(loop_list));

if(new==NULL)

{

printf("create fail\n");

return NULL;

}

new->data=data;

return new;

}

//头插

void insert_head(loop_p L,datatype data)

{

if(L==NULL)

{

printf("data fail\n");

return;

}

loop_p new=create_node(data);

new->next=L->next;

L->next=new;

L->len++;

}

//输出

void out_put_loop(loop_p L)

{

loop_p p=L->next;

while(p!=L)

{

printf("%d--->\n",p->data);

p=p->next;

}

putchar(10);

}

//按位置插入

void insert_pos(loop_p L,datatype data,int pos)

{

loop_p new=create_node(data);

loop_p p=L;

for(int i=0;i<pos-1;i++)

{

p=p->next;

}

new->next=p->next;

p->next=new;

L->len++;

}

//尾删

void del_tail(loop_p L)

{

loop_p p=L;

while(p->next->next!=L)

{

p=p->next;

}

loop_p del=p->next;

p->next=L;

free(del);

L->len--;

}

//按位置删除

int del_pos(loop_p L,datatype pos)

{

loop_p p=L;

for(int i=0;i<pos-1;i++)

{

p=p->next;

}

loop_p del = p->next;

p->next=p->next->next;

free(del);

L->len--;

}

#ifndef LOOP_LIST_H

#define LOOP_LIST_H

#include <stdio.h>

#include <stdlib.h>

typedef int datatype;

typedef struct loop_list

{

union

{

int len;

datatype data;

};

struct loop_list *next;

}loop_list,*loop_p;

//创建单向循环链表

loop_p create_head();

//创建节点

loop_p create_node(datatype data);

//头插

void insert_head(loop_p L,datatype data);

//按位置插入

void insert_pos(loop_p L,datatype data,int pos);

//输出(看现象)

void out_put_loop(loop_p L);

//尾删

void del_tail(loop_p L);

//按位置删除

int del_pos(loop_p L,datatype pos);

#endif

#include "loop_list.h"

int main()

{

loop_p L=create_head();

insert_head(L,1);

insert_head(L,2);

insert_head(L,3);

insert_pos(L,4,2);

//del_tail(L);

del_pos(L,2);

out_put_loop(L);

return 0;

}

相关推荐
问道飞鱼3 分钟前
每日学习一个数据结构-B+树
数据结构·b树·学习
DKPT10 分钟前
数据结构之快速排序、堆排序概念与实现举例
java·数据结构·算法
Element_南笙26 分钟前
数据结构_1、基本概念
数据结构·人工智能
巭犇40 分钟前
c语言中define使用方法
c语言·开发语言
熙曦Sakura1 小时前
【数据结构】队列
数据结构
sjsjs111 小时前
【数据结构-扫描线】力扣57. 插入区间
数据结构·算法·leetcode
xiaozhang_749338011 小时前
数据结构day2
数据结构
王哈哈嘻嘻噜噜1 小时前
数据结构中线性表的定义和特点
数据结构·算法
MogulNemenis1 小时前
力扣415周赛
java·数据结构·算法·leetcode
奇点 ♡2 小时前
【线程】线程的控制
linux·运维·c语言·开发语言·c++·visual studio code