数据结构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;

}

}

}

相关推荐
kyriewen35 分钟前
百度用6%成本碾压硅谷?中国AI把性价比玩明白了
前端·百度·ai编程
kyriewen1 小时前
你还在手动敲命令部署?GitHub Actions 让你 push 即上线,摸鱼时间翻倍
前端·面试·github
想学习java初学者2 小时前
SpringBoot整合Vertx-Mqtt多租户(优化版)
java·spring boot·后端
AC赳赳老秦2 小时前
政企内网落地:OpenClaw 离线环境深度适配方案,无外网场景下本地化模型对接与全功能使用
java·大数据·运维·python·自动化·deepseek·openclaw
weixin_449173652 小时前
在 Java 中,‌线程安全的 List‌ 主要有以下几种实现方式,它们的效率取决于具体的使用场景(尤其是读写比例):
java·线程安全的list
砚底藏山河2 小时前
股票数据API接口:如何获取股票历历史分时KDJ数据
java·python·maven
Csvn3 小时前
Pinia 状态管理
前端
不减20斤不改头像3 小时前
手机一句话开发贪吃蛇!TRAE SOLO 移动端 AI 编程实测
前端·后端
xuankuxiaoyao3 小时前
Vue.js实践-组件基础下
前端·javascript·vue.js
炸膛坦客3 小时前
嵌入式 - 数据结构与算法:(1-7)数据结构 - 顺序表和链表的对比
数据结构·链表