当前位置: 首页 > news >正文

数据结构第2天作业 8月3日

 单向链表

typedef int datatype;   //由于有效数据不一定是正数,所以将数据重命名。typedef struct lklst{   //不能是无名结构体了,因为定义指针域的时候需要使用union{int len;                   //头结点时候使用;datatype data;           //有效数据结点时候使用;}text;                   //数据域,存储数据struct lklst *next;     //指针域,指向下一个结点,存储下一个结点的首地址
}Linklist;

创建空的单链表

Linklist * createlinklist(void){//在堆空间中申请头结点//判断是否生成 成功Linklist *link=(Linklist*) malloc(sizeof(Linklist));//malloc申请堆空间,返回的是void*类型所以需要强转成需要的类型if(link == NULL){printf("堆空间申请失败");return NULL;}link->next=NULL;link->text.len=0;return link;
}

头插

//头插法插入数据
void insert_linklistByHead(Linklist *head,datatype data){//创建节点Linklist * temp=(Linklist*) malloc(sizeof(Linklist));if(temp == NULL){printf("堆空间申请失败");return ;}temp->next=NULL;temp->text.data=data;//temp->next=head->next;head->next=temp;//更新头节点数据的长度head->text.len++;return;
}

尾插

//尾插法插入数据
void insert_linklistByEnd(Linklist *head,datatype data){//创建节点Linklist * temp=(Linklist*) malloc(sizeof(Linklist));if(temp == NULL){printf("堆空间申请失败");return ;}temp->next=NULL;temp->text.data=data;Linklist * read =head;//找到尾节点while(read->next!=NULL){read =read->next;}read->next=temp;//更新长度head->text.len++;
}

按位置插入

//按位置插入
void insert_linklistByPosition(Linklist *head,datatype data,int n) {if (n < 1) {printf("非法数据\n");return;}Linklist *p = head;for (int i=0;i<n-1;i++) {p=p->next;if(p==NULL){printf("非法数据\n");return;}}Linklist * temp=(Linklist*) malloc(sizeof(Linklist));if(temp == NULL){printf("堆空间申请失败");return ;}temp->text.data=data;temp->next = NULL;
//将temp插入到p结点的后一个位置temp->next=p->next;temp->text.data=data;p->next=temp;//更新长度head->text.len++;return;
}

头删

void delete_linklistByHead(Linklist *head){//判断链表是否为空if(head->next==NULL)return;//先将要释放的结点地址另存Linklist * temp = head->next;//要释放结点中存储下一个结点的地址,给头结点head->next=temp->next;//释放结点free(temp);temp=NULL;//更新长度head->text.len--;return ;
}

尾删

//尾删
void delete_linklistByEnd(Linklist *head){//判断链表是否为空if(head->next==NULL)return;//寻找倒数第二个结点Linklist * temp =head;while(temp->next->next != NULL) {temp = temp->next;}//释放结点free(temp->next);temp->next = NULL;//更新长度head->text.len--;
}

按位置删除

//按位置删除
void delete_linklistByPosition(Linklist *head,int n){if(head->next==NULL){printf("非法数据\n");return;}if(n<1){printf("非法数据\n");return;}//找到要删除结点的前一个节点位置Linklist* p = head;for(int i=0;i<n-1;i++)p=p->next;if(NULL == p->next){printf("n=%d删除位置非法\n",n);return;}//能运行到这个位置,则说明p指向的是要删除的结点的前一个位置Linklist* temp = p->next;p->next = temp->next;free(temp);temp = NULL;//更新长度head->text.len++;return ;
}

 遍历链表

//遍历链表
void Iterative_list(Linklist *head){//读头节点的数据Linklist * read =head;while(read->next!=NULL){read =read->next;datatype data = read->text.data;printf("%d\t",data);}putchar(10);
}


单向循环链表

typedef int datatype;   //由于有效数据不一定是正数,所以将数据重命名。typedef struct loopklst{   //不能是无名结构体了,因为定义指针域的时候需要使用union{int len;                   //头结点时候使用;datatype data;           //有效数据结点时候使用;}text;                   //数据域,存储数据struct loopklst *next;     //指针域,指向下一个结点,存储下一个结点的首地址
}LoopLinklist;
//创建一个空的单链表
LoopLinklist * create_recurringlinklist(void) {LoopLinklist * head = (LoopLinklist *) malloc(sizeof(LoopLinklist));if (NULL == head){printf("单向循环链表创建失败\n");return NULL;}head->text.len =0;//头结点中记录的链表长度赋值为0head->next =head;//将指针域指向自己return head;
}

头插

//头插
void insert_recurringlinklistByHead(LoopLinklist *head,datatype data){//创建节点LoopLinklist * temp=(LoopLinklist*) malloc(sizeof(LoopLinklist));LoopLinklist * p=head;if(temp == NULL){printf("堆空间申请失败");return ;}temp->text.data=data;temp->next=p->next;head->next=temp;//更新头节点数据的长度head->text.len++;return;
}

尾插

//尾插
void insert_recurringlinklistByEnd(LoopLinklist *head,datatype data){LoopLinklist *temp=(LoopLinklist *) malloc(sizeof (LoopLinklist ));if(temp==NULL){printf("创建失败");return;}LoopLinklist * p=NULL;p=head;while(p->next!=head){p=p->next;}temp->next=head;temp->text.data=data;p->next=temp;head->text.len++;return;
}

按位置插入

void insert_recurringlinklistByPosition(LoopLinklist *head,datatype data,int n){if (n < 1) {printf("非法数据\n");return;}LoopLinklist *p = head;for (int i=0;i<n-1;i++) {p=p->next;if(p==NULL){printf("非法数据\n");return;}}LoopLinklist * temp=(LoopLinklist*) malloc(sizeof(LoopLinklist));if(temp == NULL){printf("堆空间申请失败");return ;}temp->text.data=data;temp->next = NULL;//将temp插入到p结点的后一个位置temp->next=p->next;temp->text.data=data;p->next=temp;//更新长度head->text.len++;return;
}

头删

//头删
void delete_recurringlinklistByHead(LoopLinklist *head){LoopLinklist *temp=head->next;if(head->next==head){printf("链表为空,删除失败");return;}temp=temp->next;free(head->next);head->next=temp;return;
}

尾删

//尾删
void delete_recurringlinklistByEnd(LoopLinklist *head){//判断链表是否为空LoopLinklist *p=head;if(head->next==head){printf("链表为空");return;}//找到倒数第二个结点while(p->next->next!=head){p=p->next;}//free(p->next);p->next=head;//更新长度head->text.len--;return;
}

按位置删除

//位置删除
void delete_recurringlinklistByPosition(LoopLinklist *head,int n){if(head->next==head){printf("非法数据\n");return;}if(n<1){printf("非法数据\n");return;}//找到要删除结点的前一个节点位置LoopLinklist* p = head;for(int i=0;i<n-1;i++)p=p->next;if(p->next==head){printf("n=%d删除位置非法\n",n);return;}//能运行到这个位置,则说明p指向的是要删除的结点的前一个位置LoopLinklist* temp = p->next;p->next = temp->next;free(temp);temp = NULL;//更新长度head->text.len++;return ;
}

遍历链表

//遍历循环单向链表
void Iterative_recurringlinklist(LoopLinklist *head){//读头节点的数据LoopLinklist * read =head;while(read->next!=head){read =read->next;datatype data = read->text.data;printf("%d\t",data);}putchar(10);
}

双向链表

typedef int datatype;   //由于有效数据不一定是正数,所以将数据重命名。typedef struct Dublinklist{   //不能是无名结构体了,因为定义指针域的时候需要使用union{int len;                   //头结点时候使用;datatype data;           //有效数据结点时候使用;}text;                   //数据域,存储数据struct loopklst *prev;  //指针域,指向上一个结点,存储上一个结点的首地址struct loopklst *next;     //指针域,指向下一个结点,存储下一个结点的首地址
}Dublist;
Dublist * create_Dublinklist(void){//判断是否生成 成功Dublist *link=(Dublist*) malloc(sizeof(Dublist));//malloc申请堆空间,返回的是void*类型所以需要强转成需要的类型if(link == NULL){printf("堆空间申请失败");return NULL;}link->prev=NULL;link->next=NULL;link->text.len=0;return link;
}

头插

void insert_DublistByHead(Dublist *head,datatype data){Dublist *temp=(Dublist *) malloc(sizeof (Dublist));if(temp==NULL){printf("堆空间申请失败");return;}Dublist *p=head;temp->text.data=data;//nexttemp->next=head->next;head->next=temp;//prvetemp->prev=head;if(temp->next!=NULL){temp->next->prev=temp;}head->text.len++;return;
}

尾插

void insert_DublistByEnd(Dublist *head,datatype data){Dublist *temp=(Dublist *) malloc(sizeof (Dublist));if(temp==NULL){printf("堆空间申请失败");return;}Dublist *p=head;temp->text.data=data;//找尾部的位置while(p->next!=NULL){p=p->next;}//nexttemp->next=p->next;p->next=temp;//prvetemp->prev=p;//更新长度head->text.len++;return;
}

按位置插入

//按位置插入
void insert_DublistByPosition(Dublist *head,datatype data,int n) {if (n < 1) {printf("非法数据\n");return;}Dublist *p = head;for (int i=0;i<n-1;i++) {p=p->next;if(p==NULL){printf("非法数据\n");return;}}Dublist * temp=(Dublist*) malloc(sizeof(Dublist));if(temp == NULL){printf("堆空间申请失败");return ;}temp->text.data=data;temp->next = NULL;
//将temp插入到p结点的后一个位置temp->next=p->next;temp->text.data=data;p->next=temp;//更新长度head->text.len++;return;
}

头删

//头删
void delete_DublistByHead(Dublist *head){if(head->next==NULL){printf("非法数据\n");return;}Dublist * temp=head->next;head->next=temp->next;head->next->prev=head;free(temp);temp=NULL;return;
}

尾删

void delete_DublistByEnd(Dublist *head){Dublist * p=head;//判断链表是否为空if(head->next==NULL)return;//寻找倒数第二个结点Dublist * temp =head;while(temp->next->next != NULL) {temp = temp->next;}//释放结点free(temp->next);temp->next = NULL;//更新长度head->text.len--;return;
}

按位置删除

//按位置删除
void delete__DublistByPosition(Dublist*head,int n){if(head->next==NULL){printf("非法数据\n");return;}if(n<1){printf("非法数据\n");return;}//找到要删除结点的前一个节点位置Dublist* p = head;for(int i=0;i<n-1;i++)p=p->next;if(NULL == p->next){printf("n=%d删除位置非法\n",n);return;}//能运行到这个位置,则说明p指向的是要删除的结点的前一个位置Dublist* temp = p->next;p->next = temp->next;free(temp);temp = NULL;//更新长度head->text.len++;return ;
}


 

相关文章:

数据结构第2天作业 8月3日

单向链表 typedef int datatype; //由于有效数据不一定是正数&#xff0c;所以将数据重命名。typedef struct lklst{ //不能是无名结构体了&#xff0c;因为定义指针域的时候需要使用union{int len; //头结点时候使用&#xff1b;datatype data; …...

设计界的新宠:5款热门UI在线设计软件评测

随着用户界面设计行业的蓬勃发展&#xff0c;越来越多的设计师进入用户界面设计。选择一个方便的用户界面设计工具尤为重要&#xff01;除了传统的用户界面设计工具&#xff0c;在线用户界面设计工具也受到越来越多设计师的青睐。这种不受时间、地点、计算机配置限制的工作方法…...

github添加ssh密钥,通过ssh方式推送代码

左手编程&#xff0c;右手年华。大家好&#xff0c;我是一点&#xff0c;关注我&#xff0c;带你走入编程的世界。 公众号&#xff1a;一点sir&#xff0c;关注领取python编程资料 很多人在使用github的时候&#xff0c;如果还是使用https的方式推送代码的话&#xff0c;可能会…...

Python设计模式 - 抽象工厂模式

定义 抽象工厂模式是一种创建型设计模式&#xff0c;它提供了一种创建一系列相关或相互依赖对象的接口&#xff0c;而无需指定它们具体的类。 产品等级结构与产品族 为了更好地理解抽象工厂模式&#xff0c;先引入两个概念&#xff1a; 产品等级结构&#xff1a;就是产品的…...

【JavaEE初阶】懒汉模式与饿汉模式及指令重排序问题

目录 &#x1f4d5; 单例模式 &#x1f333; 饿汉模式 &#x1f6a9; 线程安全 &#x1f38d; 懒汉模式 &#x1f6a9; 懒汉模式-单线程版 &#x1f6a9; 懒汉模式-多线程版 &#x1f384; 指令重排序 &#x1f4d5; 单例模式 单例模式是一种经典的设计模式&#xff0c;…...

Vue3使用Cascader 级联选择器如何获取值并提交信息

我写了一个用户对象&#xff0c;有address地址字段&#xff0c;我怎么将用户选择的级联数据selectedValue值传给address&#xff0c;并将对象返回给后端&#xff0c;核心代码实现了该问题。 <script> 核心代码&#xff1a; //获取住址并更新给addresslet selectedValue…...

Python面试整理-第三方库

Python社区提供了大量的第三方库,这些库扩展了Python的功能,覆盖了从数据科学到网络应用开发等多个领域。以下是一些非常流行和广泛使用的第三方库: 1. NumPy ● 用途:数值计算。 ● 特点:提供了一个强大的N维数组对象和大量用于数学运算的函数。 ● 应用场景:科学计算、…...

电脑添加虚拟网卡与ensp互联,互访

一、按照过程 1、打开设备管理器 2、点击网络适配器&#xff0c;点击左上角操作&#xff0c;点击“添加过时硬件” 3、下一页 4、选择“安装我手动从列表选择的硬件”&#xff0c;下一页 5、下拉&#xff0c;选择“网络适配器”&#xff0c;下一页 6、厂商选择“Microsoft”&…...

悬而未决:奇怪的不允许跨域CORS policy的问题

我在本地HBuilderX中进行预览写好的前端网页&#xff0c;它里面用了ajax访问了远程服务器的后端API网址&#xff0c;不出意外地报不允许跨域访问的错了&#xff1a;Access to XMLHttpRequest at ‘http://xxx.com/MemberUser/login’ from origin ‘http://mh.com’ has been b…...

索引优化秘籍:SQL Server数据库填充因子的调优艺术

索引优化秘籍&#xff1a;SQL Server数据库填充因子的调优艺术 在SQL Server的性能优化中&#xff0c;索引起着至关重要的作用。而索引填充因子&#xff08;Fill Factor&#xff09;则是控制索引页填充程度的重要参数&#xff0c;它直接影响索引的存储效率和查询性能。本文将深…...

ffmpeg 的内存分配架构

------------------------------------------------------------ author: hjjdebug date: 2024年 08月 01日 星期四 18:00:47 CST descripton: ffmpeg 的内存分配架构1 ------------------------------------------------------------ ffmpeg 的内配分配搞的人晕菜&#…...

Vue+live2d实现虚拟人物互动(一次体验叙述)

目录 故事的开头&#xff1a; 最终的实现效果&#xff1a; 实现步骤&#xff1a; 第一步&#xff1a;下载重要文件 第二步&#xff1a;创建vue项目文件&#xff0c;将刚下载文件拷贝到public目录下 第三步&#xff1a;在index.html文件中引入js 第四步&#xff1a;使用&…...

内联函数的概念和用途以及区别

内联函数&#xff08;Inline Function&#xff09;是C&#xff08;以及C99之后的C语言&#xff09;中的一个特性&#xff0c;旨在通过减少函数调用的开销来提高程序的执行效率。在正常情况下&#xff0c;当程序调用一个函数时&#xff0c;会发生一系列的操作&#xff0c;包括保…...

rust 桌面 sip 软电话(基于tauri 、pjsip库)

本文尝试下rust 的tauri 桌面运用 原因在于体积小 1、pjsip 提供了rust 接口官方的 rust demo 没编译出来 在git找了个sip-phone-rs-master https://github.com/Charles-Schleich/sip-phone-rs 可以自己编译下pjsip lib库替换该项目的lib 2、创建一个tauri demo 引用 [depe…...

Linux 进程优先级、程序地址空间、进程控制

个人主页&#xff1a;仍有未知等待探索-CSDN博客 专题分栏&#xff1a; Linux 目录 一、进程优先级 1、什么是进程优先级&#xff1f; 2、为什么要有优先级&#xff1f; 3、Linux的优先级特点、查看方式 4、命令行参数和环境变量 1.命令行参数 2.环境变量 获取环境变量的…...

学习笔记一

vector 在创建时指定初始大小和初始值&#xff1a; vector<int> a(5, 1) // 包含 5 个整数的 vector&#xff0c;每个值都为 1 可以使用 push_back 方法向 vector 中添加元素&#xff1a; a.push_back(7) // 将整数 7 添加到 vector 的末尾 可以使用 size(…...

Linux中信号的发送及信号的自定义捕捉方法

预备知识&#xff1a; 信号产生时进程早已知道该信号如何处理。 信号产生时进程可能并不能立即处理信号而是等到合适的时候处理。 信号其他相关常见概念 实际执行信号的处理动作称为信号递达(Delivery) 信号从产生到递达之间的状态,称为信号未决(Pending)。 进程可以选择阻…...

yum仓库的制作与使用

目录 前言&#xff1a; 1 查看系统内核 2 获取网络源 3 搭建yum网络仓库 4 rpm包的下载 4.1 将rpm包下载至本地 4.2 对下载的rpm包进行备份 5 制作本地yum源 5.1 软件仓库制作工具createrepo 5.2 使用createrepo创建本地yum仓库 6 搭建docker本地仓库 前言&#x…...

牛客周赛54:D.清楚姐姐跳格子(bfs)

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 \,\,\,\,\,\,\,\,\,\,老妪遂递一羊皮卷轴&#xff0c;上面什么都没有&#xff0c;清楚欲问&#xff0c;老妪却缄口不言。           \,\,\,\,\,\,\,\,\,\,清楚性格刚直&…...

用户空间 lmkd

用户空间 lmkd 1、概览1.1 配置lmkd 2、lmkd2.1 lmkd启动2.2 时序图 Android LowMemoryKiller原理分析 AOSP>文档>核心主题低内>存终止守护程序 1、概览 Android Low Memory Killer Daemon &#xff1a;system/memory/lmkd/README.md Android 低内存终止守护程序 (lm…...

vscode里如何用git

打开vs终端执行如下&#xff1a; 1 初始化 Git 仓库&#xff08;如果尚未初始化&#xff09; git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

Vue记事本应用实现教程

文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展&#xff1a;显示创建时间8. 功能扩展&#xff1a;记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...

STM32标准库-DMA直接存储器存取

文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA&#xff08;Direct Memory Access&#xff09;直接存储器存取 DMA可以提供外设…...

tree 树组件大数据卡顿问题优化

问题背景 项目中有用到树组件用来做文件目录&#xff0c;但是由于这个树组件的节点越来越多&#xff0c;导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多&#xff0c;导致的浏览器卡顿&#xff0c;这里很明显就需要用到虚拟列表的技术&…...

学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”

2025年#高考 将在近日拉开帷幕&#xff0c;#AI 监考一度冲上热搜。当AI深度融入高考&#xff0c;#时间同步 不再是辅助功能&#xff0c;而是决定AI监考系统成败的“生命线”。 AI亮相2025高考&#xff0c;40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕&#xff0c;江西、…...

uniapp 开发ios, xcode 提交app store connect 和 testflight内测

uniapp 中配置 配置manifest 文档&#xff1a;manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号&#xff1a;4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …...

nnUNet V2修改网络——暴力替换网络为UNet++

更换前,要用nnUNet V2跑通所用数据集,证明nnUNet V2、数据集、运行环境等没有问题 阅读nnU-Net V2 的 U-Net结构,初步了解要修改的网络,知己知彼,修改起来才能游刃有余。 U-Net存在两个局限,一是网络的最佳深度因应用场景而异,这取决于任务的难度和可用于训练的标注数…...

Leetcode33( 搜索旋转排序数组)

题目表述 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nu…...

如何通过git命令查看项目连接的仓库地址?

要通过 Git 命令查看项目连接的仓库地址&#xff0c;您可以使用以下几种方法&#xff1a; 1. 查看所有远程仓库地址 使用 git remote -v 命令&#xff0c;它会显示项目中配置的所有远程仓库及其对应的 URL&#xff1a; git remote -v输出示例&#xff1a; origin https://…...

2025.6.9总结(利与弊)

凡事都有两面性。在大厂上班也不例外。今天找开发定位问题&#xff0c;从一个接口人不断溯源到另一个 接口人。有时候&#xff0c;不知道是谁的责任填。将工作内容分的很细&#xff0c;每个人负责其中的一小块。我清楚的意识到&#xff0c;自己就是个可以随时替换的螺丝钉&…...