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

}

}

}

相关推荐
llz_1126 分钟前
web-第二次课后作业
前端·后端·web
vipbic5 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?
java·数据库·分布式·mysql·面试
来杯@Java7 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦7 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
卷毛的技术笔记7 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
编程大师哥7 小时前
匿名函数 lambda + 高阶函数
java·python·算法
喵个咪7 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
東雪木8 小时前
多线程与并发编程 专属复习笔记
java·开发语言·笔记·java面试