1.自己实现单向循环链表的功能
//loop_list.c
#include"loop_list.h"
//创建单向循环链表
loop_p create_head()
{
loop_p H=(loop_p)malloc(sizeof(loop_list));
if(H==NULL)
{
printf("空间申请失败\n");
return NULL;
}
H->len=0;
H->next=H;
return H;
}
//创建结点
loop_p create_node(datatype data)
{
loop_p new=(loop_p)malloc(sizeof(loop_list));
if(new==NULL)
{
printf("空间申请失败\n");
return NULL;
}
new->data = data;
return new;
}
//输出
void out_put_loop(loop_p H)
{
if(H==NULL)
{
printf("入参为空,请检查\n");
return;
}
loop_p p=H->next;
while(p!=H)
{
printf("%d->",p->data);
p=p->next;
}
printf("%c",'H');
putchar(10);
}
//头插
void insert_head(loop_p H,datatype data)
{
if(H==NULL)
{
printf("入参为空,请检查\n");
return;
}
loop_p new=create_node(data);
new->next=H->next;
H->next=new;
H->len++;
}
//按位置插入
void insert_pos(loop_p H,datatype data,int pos)
{
if(H==NULL)
{
printf("入参为空,请检查\n");
return;
}
if(pos<=0||pos>H->len+1)
{
printf("位置不合理\n");
return;
}
loop_p p=H;
for(int i=0;i<pos-1;i++)
{
p=p->next;
}
loop_p new=create_node(data);
new->next=p->next;
p->next=new;
H->len++;
}
//尾删
void del_tail(loop_p H)
{
if(H==NULL)
{
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--;
}
//按位置删除
void del_pos(loop_p H,int pos)
{
if(H==NULL)
{
printf("入参为空,请检查\n");
return;
}
if(pos<=0||pos>H->len)
{
printf("位置不合理\n");
return;
}
loop_p p=H;
for(int i=0;i<pos-1;i++)
{
p=p->next;
}
loop_p del=p->next;
p->next = p->next->next;
free(del);
H->len--;
}
//loop_list.h
#ifndef __LOOP_LIST_H__
#define __LOOP_LIST_H__
#include<stdio.h>
#include<string.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 out_put_loop(loop_p H);
//头插
void insert_head(loop_p H,datatype data);
//按位置插入
void insert_pos(loop_p H,datatype data,int pos);
//尾删
void del_tail(loop_p H);
//按位置删除
void del_pos(loop_p H,int pos);
#endif
//main.c
#include"loop_list.h"
int main(int argc, const char *argv[])
{
loop_p H=create_head();
insert_head(H,89);
insert_head(H,55);
insert_head(H,7);
out_put_loop(H);
insert_pos(H,12,2);
out_put_loop(H);
del_tail(H);
out_put_loop(H);
del_pos(H,1);
out_put_loop(H);
return 0;
}
2.复习前面顺序表和链表的代码,重写链表逆置函数
void overturn_link(link_p H)
{
if(H==NULL)
{
printf("入参为空,请检查\n");
return;
}
if(link_empty(H))
{
printf("链表为空\n");
return;
}
if(H->next->next==NULL)
{
printf("表中只有一个元素,无需翻转\n");
return;
}
link_p p=H->next->next;
H->next->next=NULL;
link_p q=p->next;
while(p!=NULL)
{
p->next=H->next;
H->next=p;
p=q;
if(q!=NULL)
{
q=q->next;
}
}
}