引言:

本题其实是来源于一个非常著名的犹太故事--------约瑟夫环!

        罗马人攻占了桥塔帕特,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓。于是决定了自杀方式,41个人排成一个圆圈,由第1个人开始报数,每报数到第3人该人就必须自杀。然后下一个重新报数,直到所有人都自杀身亡为止。然而Josephus 和他的朋友并不想遵从,Josephus要他的朋友先假装遵从,他将朋友与自己安排在第16个与第31个位置,于是逃过了这场死亡游戏。

编译环境: Debain Ubuntu gcc

测试图片:

QQ图片20181228001505.png

解题思路:
数学公式推导:

  /* If number = 3

     * f(1) = 0

     * f(2) = 1 = (f(1) + 3) % 2

     * f(3) = 1 = (f(2) + 3) % 3

     * f(4) = 0 = (f(3) + 3) % 4

     * f(5) = 3 = (f(4) + 3) % 5

     * ...

     * f(n) = x = (f(n-1) + 3) % n

     * */

   结果应该是f(n)+1。
参考代码:

  1 #include <iostream>
  2 #include <list>      //链表
  3 using namespace std;
  4 int main()
  5 {
  6     int total  = 0;
  7     cin >> total;    //输入环总数
  8     int number = 3;  //循环
  9     int last = 0;    // f(1) = 0
 10     for(int i = 2; i <= total; ++i)
 11         last = (last + number) % i;
 14     cout<< last+1 <<endl;
 15     return 0;
 16 }


点赞(5)
 

0.0分

17 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 5 条评论

浩力 3年前 回复TA
兄弟可以的!
月儿会弯 3年前 回复TA
妙不可言
都选C 5年前 回复TA
#include<iostream>
using namespace std;

void baoshu(int N)
{
	int a[N];
	int b[N];
	int k=0;
	for(int i=1;i<=N;i++)
	{
		a[i]=i;
	}
	for(int i=1;i<=N;i++)
	{
		if(a[i]%3==0)
		{
			k=i;
		}
	}
	if(k==N)
		cout<<k-1<<endl;
	else
		cout<<N<<endl;
}

int main()
{
	int N;
	cin>>N;
	if(N>3)
		baoshu(N);
	else
		cout<<2<<endl;
	return 0;
}
妹子杀手 5年前 回复TA
可以可以
我有个喵喵酱 6年前 回复TA
优秀