问题 C: Josephus问题(Ⅰ)

问题 C: Josephus问题(Ⅰ)

题目描述
n个人排成一圈,按顺时针方向依次编号1,2,3…n。从编号为1的人开始顺时针"一二"报数,报到2的人退出圈子。这样不断循环下去,圈子里的人将不断减少。最终一定会剩下一个人。试问最后剩下的人的编号。

要求程序模拟题意来实现,使用不带头结点的循环链表。本题只需要提交两个函数CreateList和 Execute的实现, 请注意提交语言使用C++。


/*********************************/
/*CreateList创建一个从1到n的不带头结点的循环链表,返回指向结点1的头指针*/
LinkList CreateList(int n);
/*Execute从链表中删除一个人。
*@h 不带头结点的单循环链表 
*@k,h指向的结点为第1个结点,删除第k个结点(含循环绕回的情况),k保证大于1.
*Execute返回第k+1个结点的指针
*/
LinkList Execute(LinkList h, int k);
/*********************************/为方便同学们测试,下面提供除两个函数外的其他代码。
#include<iostream>
using namespace std;typedef struct LNode
{int data;struct LNode *next;
} LNode, *LinkList;int main()
{int n;while(cin >> n){LinkList h;h = CreateList(n);while(--n)h = Execute(h, 2);cout << h->data << endl;delete h;}return 0;
}

输入
不超过1000组数据。
每组数据一行,每行一个正整数,代表人数n。 (1 <= n <= 1000)

输出
每组输入数据输出一行, 仅包含一个整数,代表最后剩下的人的编号。

样例输入 Copy
7
2
样例输出 Copy
7
1
提示
第一组数据出队顺序: 2 4 6 1 5 3

解题步骤

模拟题意
每次报数为2的人出局,即出局的人的后一位为重新开头
示例输入7的运算逻辑如下
在这里插入图片描述
下面是对代码的详细解析:

  1. 头文件和命名空间

    • 包含 <iostream> 头文件,用于输入输出操作。
    • 使用 using namespace std; 来避免在标准库类型和函数前加 std::
  2. 链表节点结构体定义

    • 定义了一个结构体 LNode,包含一个 int data 成员变量和一个指向同类型结构体的指针 next。这个结构体用于表示链表中的节点。
  3. 类型别名定义

    • 使用 typedef 创建了 LNode, *LinkList 的别名,方便后续代码中使用。
  4. 创建链表函数 CreateList

    • 接受一个整数参数 n,表示链表中节点的数量。
    • 动态分配一个新节点作为链表的起始节点,并初始化其数据为 1。
    • 使用循环动态分配更多的节点,并按顺序设置它们的数据,从 2 到 n。
    • 将链表的最后一个节点的 next 指针指向链表的起始节点,形成循环。
    • 返回指向链表起始节点的指针。
  5. 执行删除操作函数 Execute

    • 接受一个链表头指针 h 和一个整数 k,表示要删除的节点的序号(从 1 开始)。
    • 通过循环找到第 k-1 个节点,即要删除节点的前一个节点。
    • 将前一个节点的 next 指针指向要删除节点的下一个节点,从而删除了第 k 个节点。
    • 更新链表头指针 h 为删除操作后的下一个节点。
    • 释放要删除节点的内存。
    • 返回更新后的链表头指针。
  6. 主函数 main

    • 从标准输入读取整数 n,直到输入结束。
    • 使用 CreateList 函数创建一个长度为 n 的循环链表。
    • 使用循环调用 Execute 函数删除第 2 个节点,直到只剩下一个节点。
    • 输出剩余节点的数据。
    • 释放链表头节点的内存。
  7. 程序结束

    • 返回 0,表示程序正常结束。

代码逻辑分析

  • 这段代码模拟了一个约瑟夫环问题(Josephus problem),其中 n 表示初始人数,每次删除第 2 个节点,直到只剩下一个节点。
  • CreateList 函数创建了一个循环链表,Execute 函数实现了删除指定节点的操作。
  • 主函数中的循环模拟了约瑟夫环问题的迭代过程。

改进建议

  • 移除 Execute 函数中的 h=x->next; 这行代码,因为它是多余的。
  • main 函数中,可以在删除操作后更新 h 的值,例如使用 h = Execute(h, 2);
  • 考虑增加对输入有效性的检查,确保 n 是一个合理的正整数。

代码实现

这里因为小编的链表部分学的不是很好,所以找朋友指导了一下

代码如下(创建循环链表):

/*创建一个从1到n的不带头结点的循环链表,返回指向结点1的头指针*/
LinkList CreateList(int n){LinkList ans=new LNode;LinkList sum=ans;sum->data=1;for(int i=2;i<n+1;i++){sum->next=new LNode;sum=sum->next;sum->data=i;}sum->next=ans;return ans;
}//创建题目运算过程中所需要的循环链表,用以存储答案所存在的数字区间

代码如下(存储数据):

/*Execute从链表中删除一个人。
h为不带头结点的单循环链表,h指向的结点为第1个结点,
删除第k个结点(含循环绕回的情况),k保证大于1,Execute返回第k+1个结点的指针*/
LinkList Execute(LinkList h, int k){LinkList sum=h;for(int j=1;j<k-1;j++){sum=sum->next; }//不用分配新内存,直接使用原定义所用链表内存LinkList x=sum->next;sum->next=x->next;h=x->next;delete x;return h;
}
//在所存储的循环链表中查找答案所在正确位置并将其位置固定为h节点

完整代码

#include<iostream>
using namespace std;typedef struct LNode
{int data;  //编号 struct LNode *next;
}LNode, *LinkList;/*创建一个从1到n的不带头结点的循环链表,返回指向结点1的头指针*/
LinkList CreateList(int n){LinkList ans=new LNode;LinkList sum=ans;sum->data=1;for(int i=2;i<n+1;i++){sum->next=new LNode;sum=sum->next;sum->data=i;}sum->next=ans;return ans;
}/*Execute从链表中删除一个人。
h为不带头结点的单循环链表,h指向的结点为第1个结点,
删除第k个结点(含循环绕回的情况),k保证大于1,Execute返回第k+1个结点的指针*/
LinkList Execute(LinkList h, int k){LinkList sum=h;for(int j=1;j<k-1;j++){sum=sum->next; }//不用分配新内存,直接使用原定义所用链表内存LinkList x=sum->next;sum->next=x->next;h=x->next;delete x;return h;
}int main()
{int n;while(cin >> n){LinkList h;h = CreateList(n);while(--n)h = Execute(h,2);cout << h->data << endl;delete h;}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/34468.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高中数学:数列-解数列不等式问题的常用放缩技巧(重难点)

一、放缩技巧 技巧1 例题 证明&#xff1a;Sn&#xff1c;1 解&#xff1a; 变形 解&#xff1a; 由于第一种情况&#xff0c;我们证明了Sn&#xff1c;1&#xff0c;n≥1&#xff0c;是从第一项就开始放缩的。 发现&#xff0c;无法精确到 3 4 \frac{3}{4} 43​ 这时&am…

《2024年战略管理趋势报告》

本报告由Quantive发布。 《2024年战略管理趋势报告》这份报告深刻剖析了企业在策略管理上的当前状态、面临的挑战以及未来发展的趋势。报告指出,大多数组织在迅速适应市场变化方面存在困难,并且许多企业未能实现其战略目标,显示出策略制定与执行之间存在脱节。报告中不仅强调了…

【算法】单调队列 - 基础与应用-滑动窗口最大值

题目 给定一个数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回滑动窗口中的最大值。 思路 暴力&#xff1a;遍历一遍的过程中每次从窗口找到最大的数组&#…

攻防平台搭建与简易渗透工具箱编写

知识点&#xff1a;攻防平台搭建&#xff0c;虚拟机的网络模式详解&#xff0c;安全脚本编写 虚拟机的网络模式&#xff1a; 虚拟机&#xff08;VM&#xff09;的网络模式决定了虚拟机与宿主机以及外部网络之间的连接方式。不同的虚拟化平台&#xff08;如VMware, VirtualBox,…

【C语言小例程26/100】

题目&#xff1a;有一分数序列&#xff1a;2/1&#xff0c;3/2&#xff0c;5/3&#xff0c;8/5&#xff0c;13/8&#xff0c;21/13...求出这个数列的前20项之和。 程序分析&#xff1a;请抓住分子与分母的变化规律。 程序源代码&#xff1a; #include <stdio.h>int ma…

React Suspense的原理

React Suspense组件的作用是当组件未完成加载时&#xff0c;显示 fallback 组件。那么 Suspense 是如何实现的呢&#xff1f;React 的渲染是通过 Fiber 进行的&#xff0c;Suspense 的更新机制也是要围绕 Fiber 架构进行的。Suspense 是由两部分组成&#xff0c;实际 UI 子组件…

CAN通讯时序仲裁 【AI解答】

问&#xff1a; 1.CAN协议总线和节点时序同步如何理解 答 简单理解&#xff1a;总线上的时钟变化需要和节点上的时钟变化一致 当我们谈论CAN协议总线和节点时序同步时&#xff0c;我们实际上是在谈论如何确保在一个复杂的系统中&#xff0c;多个节点之间能够正确地进行数据…

如何在Springboot中添加事务执行?(以MySQL为例)

目录 1. 添加依赖 2. 配置数据库连接 3. 启用事务管理 4. 创建实体类和存储库 5. 创建服务类并使用Transactional注解 6. 编写测试用例 7. 运行应用程序 在Springboot中开启数据库的事务的应用开发过程中非常重要的业务&#xff0c;以下是一个使用MySQL数据库&#xff0…

Spring Cloud 常用组件——Hystrix(上)

在微服务架构中&#xff0c;服务之间的依赖关系非常复杂&#xff0c;一个服务的故障可能会导致整个系统的级联失败。Hystrix 是 Netflix 开源的一个容错库&#xff0c;它通过隔离服务之间的访问点、添加延迟容忍和容错逻辑来防止系统故障的蔓延。在这篇文章中&#xff0c;我们将…

0803功放3

1.甲乙类互补堆成功放&#xff0c; 理想12v t提供静态偏置&#xff0c;消去交越失真 2.12V Po(12)2/2RL 3.电压并联负反馈 并联减小输入电阻 电压减小输出电阻 4.-Rf/Ri 这个问题是工艺问题引起的&#xff0c;最早用PNP管用的锗管&#xff0c;后面硅工艺成熟后用的就是硅管&…

毫米波移动通信系统中的波束赋形— 基于码本的波束训练

基于码本的波束训练算法该方法在收发端都配置波束矢量的码本&#xff0c;通过波束搜索的方式发现最优的波束方向为了加快波束搜索的速度&#xff0c;往往采用逐步缩小搜索范围的方式加快搜索&#xff0c;可以将搜索算法的时间复杂度从O(N)降低到O(logN)&#xff0c;其中N表示码…

Huffman算法:原理、实现与应用

Huffman算法是一种非常有效的数据压缩算法&#xff0c;它的核心思想是利用字符在源数据中的出现频率来构建一棵Huffman树&#xff0c;从而实现对字符的重新编码。编码过程中&#xff0c;频率越高的字符将获得越短的编码&#xff0c;而频率越低的字符将获得越长的编码。这样&…

信创里程碑:TapData 人大金仓数据库产品完成兼容互认证,携手推进自主创新建设

近日&#xff0c;深圳钛铂数据有限公司&#xff08;以下简称钛铂数据&#xff09;自主研发的钛铂实时数据平台&#xff08;TapData Live Data Platform&#xff0c;TapData LDP&#xff09;与北京人大金仓信息技术股份有限公司&#xff08;以下简称“人大金仓”&#xff09; Ki…

基于单片机的智能浇花系统设计与实现

摘要: 设计了一种智能湿度感应浇花系统 。 系统以单片机 AT89S52 为控制芯片&#xff0c;利用 SLHT5-1 土壤湿度传感器来检测土壤的相对湿度&#xff0c;再通过单片机进行信息处理&#xff0c;采用模糊控制方法&#xff0c;输出控制信号&#xff0c;控制继电器的动作&…

代码随想录训练营第十八天 530二叉搜索树的最小绝对差 501二叉搜索树中的众数 236二叉树的最近公共祖先

第一题&#xff1a; 原题链接&#xff1a;530. 二叉搜索树的最小绝对差 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 使用中序遍历的方式&#xff1a;左中右。 定义一个pre节点来存放当前节点的前一个节点。 在中序的时候处理递归逻辑&#xff1a; 首先先向…

端口发布与暴露

端口发布与暴露 目录 发布端口发布到临时端口发布所有端口试一试 使用 Docker CLI使用 Docker Compose 如果你一直在跟随本指南&#xff0c;你应该理解容器为应用程序的每个组件提供了隔离的进程。每个组件 - 如 React 前端、Python API 和 Postgres 数据库 - 都运行在自己的…

PingCAP 再度入选“中国独角兽企业”,数据库领域的先锋力量

6月16日&#xff0c;2024中国&#xff08;重庆&#xff09;独角兽企业大会上&#xff0c;长城战略咨询发布了《中国独角兽企业研究报告2024》。 2023年&#xff0c;中国独角兽企业共375家&#xff0c;大数据赛道共5家。 估值排序企业名称2023年估值&#xff08;亿美元&#xff…

Huggingface Trainer:Removed shared tensor while saving问题的解决

bug概述&#xff1a;【踩坑记录&#x1f4dd;】Removed shared tensor while saving. 简单来说&#xff0c;这个bug的危害是trainer.save()无法正确存储权重。这篇博文的作者也给出了两种处理方法&#xff0c;但要么要改transformers版本&#xff0c;要么要包裹Trainer类&#…

【面试题】等保(等级保护)的工作流程

等保&#xff08;等级保护&#xff09;的工作流程主要包括以下几个步骤&#xff0c;以下将详细分点介绍&#xff1a; 系统定级&#xff1a; 确定定级对象&#xff1a;根据《信息系统等级保护管理办法》和《信息系统等级保护定级指南》的要求&#xff0c;确定需要进行等级保护的…

CRMEB开源商城系统Java版:新零售时代的技术创新与实战案例

一、引言 随着新零售概念的兴起和电子商务的飞速发展&#xff0c;企业对商城系统的需求也日益多元化和个性化。CRMEB开源商城系统Java版&#xff0c;凭借其先进的技术架构、丰富的功能模块和灵活的扩展性&#xff0c;成为了众多企业构建和扩展自身电商业务的首选。本文将对CRM…