排队枪毙游戏c语言,基于C语言实现的约瑟夫生者死者游戏

本文介绍了一个基于单循环链表实现的约瑟夫问题数学模型。游戏设定为30名旅客面临生死抉择,按特定规则淘汰,直至剩下15人。用户需输入旅客人数N、淘汰间隔M,程序将输出被淘汰旅客的序号及最终幸存者的序号。提供了链表源码下载链接。
摘要由CSDN通过智能技术生成

1 项目简介

约瑟夫生者死者游戏的大意是:30个旅客同乘一条船,因为严重超载,加上风高浪大危险万分;因此船长告诉乘客,只有将全船一半的旅客投入海中,其余人才能幸免于难。无奈,大家只得统一这种方法,并议定30个人围成一圈,由第一个人开始,依次报数,数到第9人,便将他投入大海中,然后从他的下一个人数起,数到第9人,再将他投入大海,如此循环,直到剩下15个乘客为止。问哪些位置是将被扔下大海的位置。

本游戏的数学建模如下:假如N个旅客排成一个环形,依次顺序编号1, 2, …, N。从某个指定的第S号开始。沿环计数,每数到第M个人就让器出列,且从下一个人开始重新计数,继续进行下去。这个过程一直进行到剩下K个旅客为止。(要求采用单循环链表)

本游戏要求用户输入的内容包括:

旅客的个数,也就是N的值

离开旅客的间隔书,也就是M的值

所有旅客的序号作为一组数据要求存放在某种数据结构中

本游戏要求输出的内容是包括:

离开旅客的序号

剩余旅客的序号

单循环链表

源码下载地址:https://www.write-bug.com/article/1768.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值