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

【数据结构】【C语言】【环形链表约瑟夫问题】

1.问题描述及背景:

著名的Josephus问题
据说著名犹太
历史学家
Josephus有过以下的故事:在罗⻢⼈占领乔塔帕特后,39 个犹太⼈与
Josephus及他的朋友躲到⼀个洞中,39个犹太⼈决定宁愿死也不要被⼈抓到,于是决定了⼀个⾃杀
⽅式,41个⼈排成⼀个圆圈,由第1个⼈开始报数,每报数到第3⼈该⼈就必须⾃杀,然后再由下⼀
个重新报数,直到所有⼈都⾃杀⾝亡为⽌。
然⽽Josephus 和他的朋友并不想遵从,Josephus要他的朋友先假装遵从,他将朋友与⾃⼰安排在
第16个与第31个位置,于是逃过了这场死亡游戏。

描述
编号为 1 到 n 的 n 个人围成一圈。从编号为 1 的人开始报数,报到 m 的人离开。
下一个人继续从 1 开始报数。
n-1 轮结束以后,只剩下一个人,问最后留下的这个人编号是多少?

说明:
开始5个人 1,2,3,4,5 ,从1开始报数,1->1,2->2编号为2的人离开
1,3,4,5,从3开始报数,3->1,4->2编号为4的人离开
1,3,5,从5开始报数,5->1,1->2编号为1的人离开
3,5,从3开始报数,3->1,5->2编号为5的人离开
最后留下人的编号是3

2.代码实现:

一:创建环形链表
二:一前一后创建两个指针,

#include<stdio.h>
#include<stdlib.h>
typedef struct SLNode
{
	int data;
	int* next;
}SLNode;
//申请空间:
SLNode* SLBuyNode(int x)
{
  SLNode* node=(SLNode*)malloc(sizeof(SLNode));
  node->data=x;
  node->next=NULL;
}
//创建环形链表:
SLNode*Create(int n)
{
  SLNode* phead=SLBuyNode(1);
  SLNode*ptail=phead;
  for(int i=2;i<=n;i++)
  {
   SLNode* node=SLBuyNode(i);
   ptail->next=node;
   ptail=ptail->next;
  }
  ptail->next=phead;
  return ptail;
//实现约瑟夫函数:
int ysf(int n,int m)
{
SLNode*prev=Create(n);
SLNode*cur=prev->next;
int count=1;
while(cur!=cur->next)
{
 if(count==m)
 {
  prev->next=cur->next;
  free(cur);
  cur=prev->next;
  count=1;
 }
  else
  {
   prev=cur;
   cur=cur->next;
   count++;
  }
}
return cur->data;

int main()
{
int tem=ysf(5,3)
printf("%d\n",tem);
return 0;
}

在这里插入图片描述


http://www.kler.cn/a/103842.html

相关文章:

  • 虚拟机kafka
  • 通俗介绍:什么是 Redis ?
  • Android 得到安装包的信息
  • 网络协议--IGMP:Internet组管理协议
  • Unity之ShaderGraph如何实现全息投影效果
  • ModbusTCP 转 Profinet 主站网关在博图配置案例
  • C# 文件 校验:MD5、SHA1、SHA256、SHA384、SHA512、CRC32、CRC64
  • VScode连接的服务器上使用jupyter显示请选择内核源
  • 自然语言处理---Transformer机制详解之BERT模型特点
  • vuejs实现点击导出按钮把数据加密后传到json/txt格式文件中并下载,以及上传json文件解密获得json内容
  • 生产环境元空间内存溢出(OOM)的问题排查
  • harrypotter1-aragog靶机攻略
  • 软考高项-写作准备写作步骤
  • 我们在 Linux 环境中用 C 编程时,如果对文件读写,Linux 会自动给文件加锁嘛?以及怎么加文件锁?
  • Ai写作创作系统ChatGPT网站源码+图文搭建教程+支持GPT4.0+支持ai绘画(Midjourney)/支持OpenAI GPT全模型+国内AI全模型
  • 成功项目经理总结的20个项目管理经验
  • Go中原生http服务的实现方式
  • 目标检测技术概述
  • rust学习——智能指针
  • spring常见问题汇总