数据结构D4作业

1.实现单向循环链表的功能

loop.c

#include "loop.h"

loop_p create_loop()

{

loop_p H=(loop_p)malloc(sizeof(loop));

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));

if(new==NULL)

{

printf("空间申请失败\n");

return NULL;

}

new->data=data;

return new;

}

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;

}

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 temp = H;

while(temp->next->next!=H)

{

temp=temp->next;

}

loop_p del=temp->next;

temp->next=temp->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 temp=H;

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

{

temp=temp->next;

}

loop_p del=temp->next;

temp->next=temp->next->next;

free(del);

H->len--;

}

void out_put_loop(loop_p H)

{

if(H==NULL)

{

printf("入参为空,请检查\n");

return;

}

loop_p p = H->next;

while(p!=H)

{

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

p=p->next;

}

putchar(10);

}

main.c

#include "loop.h"

int main()

{

loop_p H=create_loop();

insert_head(H,4);

insert_head(H,3);

insert_head(H,2);

insert_head(H,1);

del_tail(H);

del_pos(H,2);

out_put_loop(H);

return 0;

}

2.思维导图

见上一次作业

3.重写一遍链表逆置函数

void ovtu_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;

}

}

}

相关推荐
kk晏然4 分钟前
TypeScript 错误类型检查,前端ts错误指南
前端·react native·typescript·react
毕设源码-邱学长5 分钟前
【开题答辩全过程】以 台球俱乐部管理系统为例,包含答辩的问题和答案
java·eclipse
蜗牛^^O^10 分钟前
java中的JUC
java·开发语言
纆兰14 分钟前
汇款单的完成
前端·javascript·html
进阶小白猿22 分钟前
Java技术八股学习Day17
java·jvm·学习
带刺的坐椅28 分钟前
从 Chat 到 Agent:Solon AI 带你进入“行动派”大模型时代
java·ai·agent·solon·mcp·java25
扶苏-su30 分钟前
Java--转换流-InputStreamReader 和 OutputStreamWriter
java·开发语言
Lsx_32 分钟前
案例+图解带你遨游 Canvas 2D绘图 Fabric.js🔥🔥(5W+字)
前端·javascript·canvas
我是小疯子6633 分钟前
深度学习实现智能文本摘要
java
heartbeat..1 小时前
SQL 常用函数大全:聚合、字符串、数值、日期、窗口函数解析
java·数据库·sql·函数