【数据结构】实验四:循环链表
实验四 循环链表
一、实验目的与要求
1)熟悉循环链表的类型定义和基本操作;
2)灵活应用循环链表解决具体应用问题。
二、实验内容
题目一:有n个小孩围成一圈,给他们从1开始依次编号,从编号为1的小孩开始报数,数到第m个小孩出列,然后从出列的下一个小孩开始重新报数,数到第m个小孩又出列,……如此反复直到所有的小孩全部出列为止,求整个出列序列,例如:当n=6,m=5 时的出列序列是5,4,6,2,3,1 .
题目二:围绕着山顶有10个洞,一只狐狸和一只兔子住在各自的洞里。狐狸想吃掉兔子。一天,兔子对狐狸说:“你想吃我有一个条件,先把洞从1-10编上号,你从10号洞出发,先到1号洞找我;第二次隔1个洞找我,第三次隔2个洞找我(第一次看1号洞,第二次看3号洞,第三次看6号洞),以后依次类推,次数不限,若能找到我,你就可以饱餐一顿。不过在没有找到我以前不能停下来。”狐狸满口答应,就开始找了。它从早到晚进了100次洞,也没找到兔子,请问,兔子可能躲在几号洞里,打印输出所有安全洞的编号。(使用一个循环单链表解决问题)
三、实验结果
1)请将调试通过的源代码粘贴在下面。(代码注意书写规范、主要模块要有功能注释)
题目一源代码:
#include <cstdio>
#include <malloc.h>
#include <iostream>
using namespace std;typedef struct node{int no;//小孩编号struct node *next;
}child;//创建无头结点
void createlist(child *&head, int n){int i;child *p,*tail;//指向新建循环单链表的尾结点head=(child*)malloc(sizeof(child));head->no=1;//建立no为1结点的单链表tail=head;for(i=2;i<=n;i++){p=(child*)malloc(sizeof(child));p->no=i;//建立一个存放编号i的结点tail->next=p;tail=p;//将p结点链到末尾}tail->next=head;//构成一个首结点为head的循环单链表
}//求出列顺序(约瑟夫问题)
void joseph(int n,int m){//n->总数 m->出列数 int i,j; child *head,*p,*q;createlist(head,n);//初始化列表 //出列n个小孩for(i=1;i<=n;i++){p=head; j=1;//从head结点开始报数,报到第m-1个结点while(j<m-1){j++;//报数递增p=p->next;//移到下一个结点}q=p->next;//q指向第m个结点cout<<q->no<<" ";//该结点出列p->next=q->next;free(q);//删除q结点(出列结点) head=p->next;//从下一个结点重新开始}
}int main(){int n,m;//n->总数 m->出列数cin>>n>>m;joseph(n,m);return 0;
}
题目一结果展示:


题目二源代码:
#include <cstdio>
#include <cstdlib>
#include <iostream>
using namespace std;//创建结点
typedef struct node{int a,b;//a为安全洞的标记,b为洞的序号struct node *next;
}node;//主函数->find safe holes
int main(){node *p,*q;p=(node*)malloc(sizeof(node));p->b=1;p->a=1;q=p;//记录头结点 int i=0;while(i<9){//创建十个结点 p->next=(node*)malloc(sizeof(node));p=p->next;//移动到下一个新结点 p->b=i+2;//洞的序号p->a=0;i++;}p->next=q;//构建循环 p=p->next;//回到头结点 //寻找安全洞并标记狐狸洞(进100次洞) for(i=0;i<100;i++){int j;int temp=(i+2)%10;//序号归类为1-10 for(j=0;j<temp;j++){p=p->next;}p->a=1;//标记狐狸洞 }//输出安全洞 for(i=0;i<10;i++){if(p->a==0){//非兔子洞已经进行标记 cout<<"可能在第"<<p->b<<"个洞里面"<<endl;}p=p->next;//遍历,移动到下一个结点 }return 0;
}
题目二结果展示:

2)请分析你程序中每个功能模块的算法时间复杂度。
题目一:

构建含有n个元素的循环链表。时间复杂度为O(n)。

本段代码由两层循环构成。内层循环通过从head结点开始报数,报到第m-1个结点,此时寻找到第m个结点(利用第m-1个结点的后继结点)并删除。外层循环在每剔除一个结点后再一次进行遍历。时间复杂度为O(n²)。
题目二:

构建含有n个元素的循环链表,a为安全洞的标记,b为洞的序号。时间复杂度为O(n)。

本段代码由两层循环构成。内层循环通过题目所给的狐狸进洞的规律,对其所有进入过的洞进行标记(即a=1),便于后续锁定兔子安全洞的位置。外层循环为题目所给的狐狸进洞的总次数(即100次进洞寻找兔子),并继承上一次进洞的位置。时间复杂度为O(n²)。

通过之前化简进洞的序号,本段代码利用遍历输出安全洞的位置,即通过从开始的结点中遍历,寻找a标记为0的结点序号并输出。时间复杂度为O(n)。
其他参考:
#include<iostream>
using namespace std;// 定义结构体
struct CLNode
{int num;CLNode *next;
};
// 初始化链表
void Initlist(CLNode *&L){ //注意引用!!! L=new CLNode;L->next=L;
}
// 创建链表元素
void Creatlist(CLNode *&L,int n){CLNode *p=L;for(int i=1;i<=n;i++){CLNode *q=new CLNode;q->num=i;q->next=L; //循环链表的指针指向 p->next=q;p=q;}
}
// 输出链表元素
void Outlist(CLNode *&L){CLNode *p=L;cout<<"输出小孩序号如下:"<<endl; while(p->next!=L){p=p->next;cout<<p->num<<" ";}cout<<endl;
}
// 输出出列序列
void Output(CLNode *&L,int m){CLNode *p=L->next;CLNode *pre=L;//定义pre指针以便删除元素操作 for(int i=1;i<=m;){if(p->next==L){if(p->next->next==L)//循环结束条件 break;else{pre=pre->next->next;p=p->next->next;}}else{pre=pre->next;p=p->next;}i++;if(i==m){cout<<p->num<<" ";pre->next=p->next;CLNode *q=p;p=p->next;q->next=NULL;delete q;if(p!=L) //注意条件! i=1;elsei=0; //注意避开头结点 }}
}
// 释放空间
void Destroylist(CLNode *&L){delete L;//删除头结点
}int main(){CLNode *L; //定义头指针 Initlist(L); //初始化链表 int n,m;cout<<"请输入小孩的总人数:"<<endl;cin>>n; Creatlist(L,n); //插入链表元素 Outlist(L); //输出链表元素 cout<<"请输出出列序号:"<<endl;cin>>m;cout<<"当n="<<n<<",m="<<m<<"时的出列序号为:"<<endl;Output(L,m); //根据序号输出依次链表元素 Destroylist(L);//释放空间
}
#include<iostream>
using namespace std;
// 定义结构体
struct CLNode
{int num;CLNode *next;
};
// 初始化链表
void Initlist(CLNode *&L){ //注意引用!!! L=new CLNode;L->next=L;
}
// 创建链表元素
void Creatlist(CLNode *&L,int n){CLNode *p=L;for(int i=1;i<=n;i++){CLNode *q=new CLNode;q->num=i;q->next=L; //循环链表的指针指向 p->next=q;p=q;}
}
// 输出链表元素
void Outlist(CLNode *&L){CLNode *p=L;cout<<"输出山洞序号如下:"<<endl; while(p->next!=L){p=p->next;cout<<p->num<<" ";}cout<<endl;
}
// 寻找安全洞
void Safenum(CLNode *&L){cout<<"安全洞的编号可能为:"<<endl;CLNode *p=L;int a[101]; //储存被循环到的链表元素 int i=1;while(i<=100){ //使循环次数足够多 for(int j=0;j<i;j++){if(p->next==L)p=p->next->next;elsep=p->next;}a[i-1]=p->num;i++;}for(int j=1;j<=10;j++){for(i=0;i<100;i++){if(a[i]==j)break;} if(i>=100)cout<<j<<" ";}
}
// 释放空间
void Destroylist(CLNode *&L){CLNode *p=L->next;while(p!=L){ //除了头结点的所有结点 CLNode *q=p;p=p->next;q->next=NULL;delete q;}delete p;//删除头结点
}int main(){CLNode *L; //定义头指针 Initlist(L); //初始化链表 Creatlist(L,10); //插入链表元素 Outlist(L); //输出链表元素 Safenum(L); //找到安全洞 Destroylist(L);//释放空间
}
相关文章:
【数据结构】实验四:循环链表
实验四 循环链表 一、实验目的与要求 1)熟悉循环链表的类型定义和基本操作; 2)灵活应用循环链表解决具体应用问题。 二、实验内容 题目一:有n个小孩围成一圈,给他们从1开始依次编号,从编号为1的小孩开…...
【FPGA/D7】
2023年7月26日 串口传图到RAM并TFT显示 视频25note要求:接收两个字节数据合并为一个16位数据并写入ram: FIFO模型与应用场景 视频26 串口传图到RAM并TFT显示 视频25 note 存储器的使用,在开始读写或者结束读写的位置非常容易出现数据错误或…...
Vue的下载以及MVVM分析
😀前言本片文章是vue系列第一篇整理了vue的基础和发展史 🏠个人主页:尘觉主页 🧑个人简介:大家好,我是尘觉,希望我的文章可以帮助到大家,您的满意是我的动力😉Ƕ…...
ElasticSearch学习--自动补全
目录 自定义分词器 介绍 配置自定义分词器 拼音分词器的问题编辑 总结 DSL自动补全查询 RestAPI实现自动补全 自定义分词器 介绍 自定义分词器只在当前库中有效 配置自定义分词器 拼音分词器的问题 总结 DSL自动补全查询 RestAPI实现自动补全...
【C++】多态,虚函数表相关问题解决
文章目录 多态概念及其触发条件重写和协变(考点1)(考点2) 虚函数表及其位置(考点3) 多继承中的虚函数表 多态概念及其触发条件 多态的概念:通俗来说,就是多种形态。具体点就是去完成…...
探索大型语言模型的开源人工智能基础设施:北京开源AI Meetup回顾
原文参见Explore open source AI Infra for Large Language Models: Highlights from the Open Source AI Meetup Beijing | Cloud Native Computing Foundation 背景介绍: 最近,在 ChatGPT 的成功推动下,大型语言模型及其应用程序的流行度激…...
Langchain 的 Conversation buffer window memory
Langchain 的 Conversation buffer window memory ConversationBufferWindowMemory 保存一段时间内对话交互的列表。它仅使用最后 K 个交互。这对于保持最近交互的滑动窗口非常有用,因此缓冲区不会变得太大。 我们首先来探讨一下这种存储器的基本功能。 示例代码&…...
电流源电路
3.3.3电流源电路 镜像电流源 电路 分析 仿真 比例电流源 电路 分析 仿真 加射极输出器的电流源1 电路 分析 仿真 加射极输出器的电流源2 电路 分析 仿真 威尔逊电流源 电路 分析 仿真...
iOS开发-CMMotionManager传感器陀螺仪
iOS开发-CMMotionManager传感器陀螺仪 之前开发中遇到需要使用陀螺仪判断是否拍照时候水平判断,如果没有水平拍照,则给出提示。方便用户拍照合适的题目图片。 一、CMMotionManager CMMotionManager是什么 CMMotionManager 是 Core Motion 库的核心类&…...
影刀下载,插件安装
1、下载 在影刀官网下载:www.yingdao.com 2、谷歌插件安装 参考: 影刀插件安装各种方式 浏览器安装插件说明 - 影刀帮助中心 安装说明:驱动外置 Chrome 需要安装插件,并且保证此插件处于开启状态 方式一:用户头…...
Linux的tcpdump命令详解
tcpdump 一款sniffer工具,是Linux上的抓包工具,嗅探器 补充说明 tcpdump命令 是一款抓包,嗅探器工具,它可以打印所有经过网络接口的数据包的头信息,也可以使用-w选项将数据包保存到文件中,方便以后分析。…...
springboot运行报错Failed to load ApplicationContext for xxx
Failed to load ApplicationContext for报错解决方法 报错Failed to load ApplicationContext for 报错Failed to load ApplicationContext for 网上找了一堆方法都尝试了还是没用 包括添加mapperScan,添加配置类 配置pom文件 [外链图片转存失败,源站可能有防盗链机…...
[SQL挖掘机] - 内连接: inner join
介绍: 内连接是一种多表连接方式,用于将两个或多个表中的数据通过共同的列值进行匹配,并返回满足连接条件的匹配行。简单来说,内连接能够将相关联的数据组合在一起,以便进行更复杂和全面的数据分析。 内连接的工作原理如下&…...
mysql(四)数据备份
目录 前言 一、概述 二、备份的类型 (一)物理与逻辑角度 (二)数据库备份策略角度 三、常见的备份方法 四、完整备份 (一)打包数据库文件备份 (二)备份工具备份 五、增量备份 六、操…...
Spring 拦截器
上篇博客链接:SpringAOP详解 上篇博客我们提到使用AOP的环绕通知来完成统一的用户登陆验证虽然方便了许多,但随之而来也带来了新的问题: HttpSession不知道如何去获取,获取困难登录和注册的方法并不需要拦截,使用切点没办法定义哪…...
【libevent】http客户端3:简单封装
LibEventHttp: 适用于简单的http请求 LibEventHttp/* Copyright (c) MediaArea.net SARL. All Rights Reserved.** Use of this source code is governed by a BSD-style license that can* be found in the License.html file in the root of the source tree.*///--------…...
JavaScript的函数中this的指向
JavaScript的函数中this的指向 JavaScript 语言之所以有 this 的设计,跟内存里面的数据结构有关系。 以下例子来简单描述this在不同情况下所指向的对象。 var obj {aa: function(){console.log(this.num)},num: 5 };var aa obj.aa; var num 10;obj.aa(); // …...
Caddy 中实现自动 HTTPS
要在 Caddy 中实现自动 HTTPS,您可以按照以下步骤进行操作: 步骤 1:安装 Caddy 首先,您需要安装 Caddy 服务器。您可以从 Caddy 的官方网站(https://caddyserver.com/)下载适用于您的操作系统的最新版本。…...
SK5代理(socks5代理)在网络安全与爬虫应用中的优势与编写指南
一、SK5代理(socks5代理)的基本概念 SK5代理是一种网络代理协议,它允许客户端通过代理服务器与目标服务器进行通信。相较于HTTP代理,SK5代理在传输数据时更加高效且安全,它支持TCP和UDP协议,并且能够实现数…...
【LeetCode-简单】剑指 Offer 06. 从尾到头打印链表(详解)
题目 输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。 题目地址:剑指 Offer 06. 从尾到头打印链表 - 力扣(LeetCode) 方法1:栈 思路 题目要求我们将链表的从尾到投打印一…...
大厂Agent开发工程师亲授!这份核心技术学习路线助你轻松拿下高薪Offer!
结合个人实际的工作内容和招聘市场对于Agent开发的能力要求(阅读汇总了大量大厂的Agent开发招聘面经),我总结了一份核心技术学习路线。 这个学习路线由浅到深,基本覆盖了现在大厂对于Agent开发的技术要求,技术栈完全可…...
8-Bit美学不妥协性能|像素剧本圣殿UI渲染与LLM推理资源隔离方案
8-Bit美学不妥协性能|像素剧本圣殿UI渲染与LLM推理资源隔离方案 1. 项目概述 像素剧本圣殿(Pixel Script Temple)是一款专为剧本创作者设计的AI辅助工具,基于Qwen2.5-14B-Instruct大模型深度微调开发。它将高性能AI推理能力与独…...
淘宝虚拟商品选品实操:从儿童学习资料到游戏攻略的蓝海挖掘术
淘宝虚拟商品选品高阶指南:从儿童教育到游戏产业的精细化运营策略 在淘宝虚拟商品领域,真正能够持续盈利的卖家往往不是那些追逐热门品类的跟风者,而是懂得在细分市场中寻找差异化机会的"蓝海猎手"。儿童学习资料和游戏攻略这两个看…...
Linux内核container_of宏解析与应用
1. 理解container_of宏的核心作用在Linux内核开发中,container_of宏是一个极其重要且频繁使用的工具。它的核心功能是通过结构体成员的地址反推出整个结构体的起始地址。想象一下,你手里只有一张照片的某个局部,却能准确找到这张照片在相册中…...
【以太网帧格式】
以太网帧格式一、顺序二、分析一、顺序 前导码 | 帧开始定界符 | 目的MAC | 源MAC | 类型(长度) | 数据字段 | 帧校验序列FCS3 (以太网帧最小帧长:64 字节,最大帧长:1518 字节。) 二、分析 1…...
Python智能内存管理策略深度评测(CPython 3.9–3.12全版本横评):谁真正降低了47.6% OOM风险?
第一章:Python智能内存管理策略深度评测总览Python 的内存管理并非由开发者手动控制,而是依托于一套高度集成的智能机制——包括引用计数、循环垃圾回收器(gc 模块)以及内存池(pymalloc)三层协同体系。这种…...
告别重复编码:用快马ai自动生成c语言基础工具模块提升效率
告别重复编码:用快马AI自动生成C语言基础工具模块提升效率 在C语言开发中,我们经常需要重复编写一些基础工具模块,比如安全的字符串输入、动态数组管理、日志记录等功能。这些代码虽然不复杂,但每次都从头开始写确实很浪费时间。…...
GCN在推荐系统中的应用:如何用图神经网络提升电商个性化推荐效果
GCN在电商推荐系统中的实战指南:从二部图构建到A/B测试全流程 当你在电商平台浏览商品时,那些"猜你喜欢"的推荐背后,可能正运行着一套基于图神经网络(GCN)的复杂算法系统。与传统的协同过滤不同,GCN能够捕捉用户-商品交…...
【Skills开发实战指南】第01篇:Skills开发入门:AI助手的能力扩展革命
快速导航 读完本文,你将获得: ✅ 深入理解Skills是什么以及为什么需要它✅ 掌握Skills在AI编程工具中的核心价值✅ 了解Skills的完整生态和应用场景✅ 明确Skills开发的学习路径和资源✅ 准备好开始你的第一个Skills开发项目 一、Skills是什么…...
3分钟掌握哔哩下载姬:零安装B站视频下载神器使用指南
3分钟掌握哔哩下载姬:零安装B站视频下载神器使用指南 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#x…...
