【数据结构】【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.代码实现:

一:创建环形链表

二:一前一后创建两个指针,

c 复制代码
#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;
}
相关推荐
三品吉他手会点灯13 小时前
STM32 VSCode 开发-C/C++的环境配置中,找不到C/C++: Edit Configurations选项
c语言·c++·vscode·stm32·单片机·嵌入式硬件·编辑器
来自远方的老作者14 小时前
第10章 面向对象-10.4 继承
开发语言·python·继承·单继承·多继承·super函数
逻辑驱动的ken14 小时前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
小手cool14 小时前
如何在Java中根据另一个配对集合对一个集合进行排序
java·开发语言
升鲜宝供应链及收银系统源代码服务14 小时前
OMS 订单模块重构正式文档(一)---升鲜宝生鲜配送供应链管理系统
java·开发语言·重构·生鲜配送源代码·生鲜供应链源代码
三品吉他手会点灯14 小时前
C语言学习笔记 - 1.C概述 - 本讲内容概述
c语言·笔记·学习
qq_120840937114 小时前
Three.js 工程向:GLTFLoader 管线、Draco/KTX2 与资源管理
开发语言·javascript·ecmascript
嵌入式小企鹅14 小时前
国产大模型与芯片加速融合,RISC-V生态多点开花,AI编程工具迈入自动化新纪元
人工智能·学习·ai·嵌入式·算力·risc-v·半导体
光影少年14 小时前
Monorepo架构是什么,如何学习Monorepo架构?
前端·学习·架构·前端框架
下地种菜小叶15 小时前
定时任务系统怎么设计?一次讲清任务注册、分布式调度、幂等执行与失败补偿
java·开发语言·数据库·oracle·rabbitmq