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;

}

相关推荐
Mem0rin几秒前
[Java/数据结构]PriorityQueue
java·数据结构
m0_716765236 分钟前
数据结构--栈的插入、删除、查找详解
开发语言·数据结构·c++·经验分享·学习·青少年编程·visual studio
承渊政道15 分钟前
【递归、搜索与回溯算法】(二叉树深搜模型拆解与经典题型全面突破)
数据结构·c++·学习·算法·leetcode·macos·bfs
handler0119 分钟前
Linux基础知识(1)
linux·服务器·c语言·开发语言·数据结构·c++
yashuk20 分钟前
C语言实现PAT习题题解及算法学习笔记,附SQLite介绍
c语言·sqlite·开源项目·算法学习·pat习题
良木生香24 分钟前
【C++ 初阶】:内存管理的迭代革新——从malloc/free 到 new/delete 的时代更迭
c语言·开发语言·c++
会编程的土豆32 分钟前
常用算法里的细节
数据结构·c++·算法·图论
code_li32 分钟前
▍Type-C 不等于 Type-C,是看起来已经「统一」了
c语言·开发语言·type-c
CHANG_THE_WORLD33 分钟前
C 语言的 `fread` 与 C++ 的 `ifstream::read` 区别及设计哲学
java·c语言·c++
zore_c41 分钟前
【C++】C++——类的默认成员函数(构造、析构、拷贝构造函数)
java·c语言·c++·笔记·算法·排序算法