3030. 天黑请闭眼

单点时限: 2.0 sec

内存限制: 256 MB

“ 天黑请闭眼 ” 游戏 中,有四个角色:上帝、杀手、警察、橡皮假人,游戏规则是杀手若将警察杀死则杀手获胜。

现假设一局游戏中除杀手外,还有 n 个人,而这 n 个人中只有一个警察,剩下 n-1 个都是橡皮假人。杀手按照一定的规律杀人,他将这 n 个人围成一圈进行编号 (1,2,3,…,n),从第一个人开始,顺时针方向数到第 m 个人就将他杀掉,然后再从下一个人开始数到第 m 个人作为被杀对象,以此循环杀人。上帝知道了这个规律,为了保护警察,需要将警察放到最安全的位置(也就是最后一个被杀的位置)。现在你是上帝,请编写程序找到这个最安全的位置。

在这里插入图片描述

输入格式
第 1 行:一个整数 T(1≤T≤10)为问题数。

第 2~T+1 行: 对应每个问题有一行, 每行有两个整数 n, m,两个整数之间有一个空格。

1≤n,m≤1000

输出格式
对于每个问题,输出一行问题的编号(0 开始编号,格式:case #0: 等)

然后对应每个问题在一行中输出 警察的位置(最安全的位置)。

样例
input
3
7 4
68 34
999 333
output
case #0:
2
case #1:
13
case #2:
619

/*
约瑟夫问题,可参见一行代码能解决的问题https://blog.csdn.net/qq_40394960/article/details/105216929
*/
#include<iostream>
using namespace std;
int f(int n,int m)
{
	return n==1?n:(f(n-1,m)+m-1)%n+1;
}
int main()
{
	int t;
	cin>>t;
	for(int i =0; i < t; i++)
	{
		int n,m;
		cin>>n>>m;
		printf("case #%d:\n%d\n",i,f(n,m));
	}
	return 0;
}
也可用数学方法:
        f = 0;
        cin >> n >> m;
        for (int i=2;i<=n;i++)
            f=(f+m)%i;
        printf("case #%d:\n%d\n", t, f+1);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
天黑请闭眼”是一款非常流行的桌游,现在也有电子版,是一个很好的Java编程练手项目。以下是使用Java代码实现游戏的教程: 1. 创建玩家类 在Java中创建一个Player类,包括属性:姓名、身份、是否死亡等,并且需要实现相关方法,如询问、被投票、被杀等。 2. 创建游戏管理器 在Java中创建一个GameManager类,用于管理游戏流程和逻辑,包括:玩家的加入和退出、发牌、天黑请闭眼流程等等。需要实现主要方法,如发牌、天黑请闭眼、投票、判断输赢等等。 3. 实现游戏流程和逻辑 创建一个Game类,并创建gameStart()方法。这个方法将会初始化GameManager和Player,并且开始天黑请闭眼流程,然后执行游戏流程并且判断每个玩家的状态,最后需要判断游戏是否结束,如果结束则发表胜负结果。 4. 执行游戏流程 定义游戏流程,包括发牌、天黑请闭眼、投票、被杀等步骤。在这些步骤中需要根据玩家的身份来执行不同的操作。 5. 模拟游戏流程 进行游戏模拟,模拟游戏中的各种情况,例如角色身份随机,每个人的发言、投票和被杀的情况,直到游戏结束。 天黑请闭眼游戏的Java代码教程就是如上述的步骤。同样重要的则是一定要对面向对象编程和流程编程非常熟悉。同时也需要一些基本的Java语言能力才能够顺利的进行头黑请闭眼游戏的编程实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值