约瑟夫问题及求解方法

news2024/11/27 22:20:18

文章目录

  • 什么是约瑟夫问题?
  • 求解方法
  • 代码实现

什么是约瑟夫问题?

约瑟夫问题是一个经典的数学难题,其一般形式可以描述为:

  • n个人(编号从1到n),围坐在一张圆桌周围。
  • 从第一个人开始报数,报到m的人出列;
  • 然后从出列者的下一个人开始重新报数,报到m的人又出列;
  • 依此规律重复进行直到剩余最后一个人。所求即为胜利者的编号。

在这里插入图片描述


求解方法

  1. 枚举

如果使用枚举法列出所有可能的情况计算,时间和空间复杂度会非常大,因此需要寻找更高效的算法。

  1. 循环链队
  • 从存储结构看,队分为顺序队与链队两种。
    顺序队用一维数组连续存放队列元素,容量固定;
    链队的容量无法预先估计,可动态变化。在链队中我们设一个头结点,头指针始终指向头结点,尾指针指向队尾元素

  • 我们将n个人用链表相连,并采用类似循环队列的方式进行报数。

  • 具体来说,每次从当前节点开始逐个报数,当数到m时,删除该节点,从下一个节点重新开始报数。

  • 这个过程重复n-1次,最终留下的节点即为胜利者。

注意:在实现过程中还需要采取一些技巧来提高效率。

  • 例如,我们可以使用一个指针记录当前轮次的最后一个节点,以减少不必要的遍历。
  • 此外,由于链表在删除某个节点时需要先找到该节点的前驱节点,因此我们需要采用双向链表而非单向链表。

代码实现

  • C语言实现:
#include<stdio.h>
#include<stdlib.h>

typedef struct LNode{		//链式队列的结点 
	int data;
	struct LNode * next;
}LinkList;
int n = 41, m = 3;

//1、初始化循环单链表
LinkList *init_LinkList(LinkList *L){
	int i = 1;
	L = (LinkList*)malloc(sizeof(LinkList));
	LinkList *p=L;
	LinkList *pNew;
	
	scanf("%d", &n);
	if(n != 0)	{
		while(i <= n)		{
			pNew = (LinkList *)malloc(sizeof(LinkList));
			pNew->data = i++;
			p->next = pNew;
			p = pNew;
		}
		pNew->next=L->next;
		
	}

	free(L);			//删除头结点 
	return pNew->next;	//返回第一个数的指针
}
void del_sque(int n,LinkList *p){
	LinkList * t;

	while(p!=p->next)	{
		for(int i=1;i<m-1;i++)
			p=p->next;
		printf("%d->",p->next->data);

		t=p->next;
		p->next=t->next;
		free(t);

		p=p->next;
	}
	printf("%d\n",p->data);

	return;
}

int main(){

	LinkList *Head = NULL;
	Head = init_LinkList(Head);		//创建无头结点的循环链表 
	del_sque(n,Head);				//求解约瑟夫问题 
	
	return 0;
}
  • python实现:
class ListNode:
    def __init__(self, value):
        self.value = value
        self.next = None
        self.prev = None

def josephus(n, m):
    # 构建初始链表
    head = ListNode(1)
    cur = head
    for i in range(2, n+1):
        new_node = ListNode(i)
        cur.next = new_node
        new_node.prev = cur
        cur = new_node
    tail = cur           # 记录末尾节点

    # 进行删除操作,直至只剩1个节点
    cur = head
    while cur != cur.next:
        # 找到m-1个节点
        for _ in range(m-1):
            cur = cur.next
        # 删除当前节点
        prev, next = cur.prev, cur.next
        if prev:
            prev.next = next
        if next:
            next.prev = prev
        # 更新cur指针和tail指针
        cur = next
        tail = prev

    return tail.value  # 返回唯一留下的节点编号

# 测试代码
print(josephus(7, 3))   # 输出4

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

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

相关文章

chatgpt赋能Python-mac系统的python

在Mac系统上运行Python&#xff1a;一个简介 介绍 Python是一种流行的、易于学习的编程语言&#xff0c;被广泛用于各种用途&#xff0c;从数据分析到机器学习。如果您是Mac用户&#xff0c;那么您已经安装了Python&#xff0c;因为它是系统的一部分。本文将介绍如何在Mac系统…

Web基础 ( 五 ) JavaScript BOM

4.4.BOM浏览器对象模型 window代表窗体, 内置多种对象, 每种对象包含多种方法及属性 4.4.1.location 地址栏 window.location.href "url"; // 当前窗口加载指定的页面location.reload(); //刷新4.4.2.history 访问历史记录 window.history.back(); // 返回上一…

搞一搞用例图

前言 基于公司技术方案的设计比较重视用例图&#xff0c;重新学习一下相关内容。用例要说明参与者与用例之间的关系&#xff0c;那么对用例图相关要点进行梳理 用例图的定义及组成要素用例图的4种关系常用的用例图软件 定义与组成 用例图核心作用是将系统需求和参与者之间的…

DEJA_VU3D - Cesium功能集 之 110-椭圆(标绘+编辑)

前言 编写这个专栏主要目的是对工作之中基于Cesium实现过的功能进行整合,有自己琢磨实现的,也有参考其他大神后整理实现的,初步算了算现在有差不多实现小140个左右的功能,后续也会不断的追加,所以暂时打算一周2-3更的样子来更新本专栏(每篇博文都会奉上完整demo的源代码…

【手撕红黑树】

前言 相信很多人初学者听到了红黑树后心中不免有些心慌&#xff0c;那你看到了这篇文章后相信会有所收获&#xff0c;我其实刚开始也是对红黑树抱着一种害怕甚至是恐惧&#xff0c;但是在老师的帮助下也终于慢慢的不在恐惧了&#xff0c;你想知道为什么的话就继续往下看吧。&am…

【C,C++】内存管理new和delete

内存管理 前言正式开始几道热身题C语言动态内存管理方式C内存管理new/delete操作内置类型new和delete对于内置类型new开辟失败 operator new与operator delete函数new和delete的实现原理内置类型自定义类型 定位new表达式面试常考&#xff1a;malloc/free和new/delete的区别 前…

板子短路了?

有段时间没更新了&#xff0c;主要是最近有点忙&#xff0c;当然也因为有点“懒”。 做这行业的都知道&#xff0c;下半年都是比较忙的&#xff0c;相信大家也是&#xff01; 相信做硬件的小伙伴们&#xff0c;遇到过短路的板子已经不计其数了。 短路带来的危害&#xff1a;…

关于单目视觉 SLAM 的空间感知定位技术的讨论

尝试关于单目视觉 SLAM 的空间感知定位技术的学习&#xff0c;做以调查。SLAM算法最早在机器人领域中提出&#xff0c;视觉SLAM又可以分为单目、双目和深度相机三种传感器模式&#xff0c;在AR应用中通常使用轻便、价格低廉的单目相机设备。仅使用一个摄像头作为传感器完成同步…

Web基础 ( 四 ) JavaScript 介绍

4.JavaScript 4.1.概念 4.1.1.什么是JavaScript 通过浏览器中内置的解析器&#xff0c;逐行解析执行的一种脚本语言 主要是处理系统使用者的行为逻辑的 4.1.2.与Java语言的比较 代码格式不同 ​ Java与HTML无关的格式 ​ JavaScript代码是一种文本字符格式&#xff0c;可…

chatgpt赋能Python-numpy归一化函数

介绍&#xff1a;numpy归一化函数 在数据处理和分析中&#xff0c;常常需要将数据归一化到一定范围内&#xff0c;以便于不同数据之间进行比较和处理。在Python的数据科学方面&#xff0c;numpy库是非常常用的工具之一&#xff0c;其中的归一化函数非常便捷和有效。 在这篇文…

如何快速入门 Java?

在一线互联网公司做开发 13 年了&#xff0c;“精通”Java&#xff0c;“吊打”一众面试官&#xff0c;如何快速入门 Java&#xff0c;对我来说简直就是小儿科&#xff0c;相信看完后你一定能收获满满、醍醐灌顶&#xff0c;今年秋招拿下阿里、美团等互联网大厂的 offer。 逼装…

django ORM框架 第二章 表与表的关系关联表

目录 一、表的几种关联关系 1.1 一对一 1、介绍&#xff1a; 2、举例 3、建表原则&#xff1a; 4、django ORM 框架实现 一对一 的表的创建 1.2 一对多 1、介绍&#xff1a; 2、举例 3、建表原则&#xff1a; 4、django ORM 框架实现 一对多 的表的创建 1.3 多对多 1…

汇编八、汇编控制静态数码管显示数字

1、实现目标 通过汇编语言&#xff0c;实现单个静态数码管依次循环显示0~9。 2、数码管 2.1、数码管外观 2.2、数码管工作原理 (1)数码管的亮灭是由内部LED的亮灭实现的。 (2)一位数码管内部有八颗LED灯&#xff0c;利用内部的LED灯的亮和灭让数码管显示不同的数字。 3、…

chatgpt赋能Python-mac怎么用python

Mac如何使用Python&#xff1a;从入门到实践 简介 Mac操作系统上的Python开发环境非常受欢迎&#xff0c;因为它是一种优雅的编程语言&#xff0c;具有良好的可读性&#xff0c;可以轻松处理不同类型的任务&#xff0c;包括网站开发、机器学习和数据分析等领域。本文将介绍如…

干外包3年,彻底寄了...

先说一下自己的情况&#xff0c;大专生&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了6年的功能测试&…

瑞吉外卖 - 删除分类功能(13)

某马瑞吉外卖单体架构项目完整开发文档&#xff0c;基于 Spring Boot 2.7.11 JDK 11。预计 5 月 20 日前更新完成&#xff0c;有需要的胖友记得一键三连&#xff0c;关注主页 “瑞吉外卖” 专栏获取最新文章。 相关资料&#xff1a;https://pan.baidu.com/s/1rO1Vytcp67mcw-PD…

chatgpt赋能Python-minhash_python

MinHash Python算法&#xff1a;优化大数据处理和搜索引擎 在如今互联网化和其他技术转型的时代&#xff0c;SEO已经成为许多企业和个人的必要条件。SEO方法(搜索引擎优化)一直在不断的发展&#xff0c;MinHash算法是其中之一。本篇文章将会介绍MinHash算法和它在Python中的实…

万金油表示真干不过,部门新来的00后测试员已把我卷崩溃,想离职了...

在程序员职场上&#xff0c;什么样的人最让人反感呢? 是技术不好的人吗?并不是。技术不好的同事&#xff0c;我们可以帮他。 是技术太强的人吗?也不是。技术很强的同事&#xff0c;可遇不可求&#xff0c;向他学习还来不及呢。 真正让人反感的&#xff0c;是技术平平&#x…

chatgpt赋能Python-numpy_分割

Numpy 分割&#xff1a;简介与应用 什么是 Numpy 分割&#xff1f; Numpy 是一种基于 Python 的科学计算库&#xff0c;它提供了对多维数组的支持。其中&#xff0c;分割是 Numpy 中一个非常重要的操作&#xff0c;它允许我们将一个数组沿着指定的轴切分成多个子数组&#xf…

synchronized 底层原理

synchronized 关键字的底层原理 jdk5 之前 synchronized 是重量级锁&#xff0c;但是jdk6 之后会有一个锁升级的过程 Monitor实现的锁属于重量级锁&#xff0c;你了解过锁升级吗? Java中的synchronized有偏向锁、轻量级锁、重量级锁三种形式&#xff0c;分别对应了锁只被一个…