本文实例讲述了Java简单实现约瑟夫环算法。分享给大家供大家参考,具体如下:
1.算法背景:
罗马人攻占了乔塔帕特,41人藏在一个山洞中躲过了这场浩劫。这41个人中,包括历史学家josephus和他的一个朋友。剩余的39个人为了表示不向罗马人屈服,决定集体自杀。大家决定了一个自杀方案,所有这41人围城一个圆圈,由第一个人开始顺时针报数,没报数为3的人就立刻自杀,然后由下一个人重新开始报数
仍然是每报数为3的人就立刻自杀,......,知道所有人都自杀死亡为止.
约瑟夫和他的朋友并不想自杀,于是约瑟夫想到了一个计策,他们两个同样参数到自杀方案中,但是最后却躲过了自杀。请问是怎么做到的
2.下面直接代码进行实现:
public class YueSeFuHuan { static final int nums = 41;// 总共多少人 static final int killMan = 3;// 数到3则被杀 public static void main(String[] args) { jufehus(2); } public static void jufehus(int alive) { int[] man = new int[nums];// 未被杀的都被标记为0 int pos = -1;// 数组角标 int i = 0; int count = 1;// 杀到第几个记录值 while (count <= nums) { do { pos = (pos + 1) % nums;// 循环标记 if (man[pos] == 0) i++; if (i == killMan) { i = 0; // 重置 break;// 找到了被杀的位置,跳出循环,进行标记 } } while (true); man[pos] = count; count++; } System.out.println("编程网测试结果:"); // 显示不被杀的位置 alive = count - alive; for (int j = 0; j < man.length; j++) { if (man[j] >= alive) System.out.println("不被杀的位置是->" + (j + 1)); } }}
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容猜你喜欢
AI推送时光机Java简单实现约瑟夫环算法示例
后端开发2023-05-31
Java使用单链表实现约瑟夫环
后端开发2024-04-02
C++实现约瑟夫环的循环单链表
后端开发2024-04-02
Java中怎么实现一个约瑟夫环
后端开发2023-06-17
Python实现约瑟夫环问题的方法
后端开发2022-06-04
C语言用循环单链表实现约瑟夫环
后端开发2024-04-02
C语言版约瑟夫问题算法实现
后端开发2024-04-02
C/C++经典算法之约瑟夫问题的示例分析
后端开发2023-06-20
如何实现C语言版约瑟夫问题算法
后端开发2023-06-22
详解基于C++实现约瑟夫环问题的三种解法
后端开发2024-04-02
Java数据结构与算法之双向链表、环形链表及约瑟夫问题深入理解
后端开发2024-04-02
java 实现MD5加密算法的简单实例
后端开发2023-05-31
Java递归算法简单示例两则
后端开发2023-05-31
Python栈算法的实现与简单应用示例
后端开发2022-06-04
Java简单实现UDP和TCP的示例
后端开发2023-05-30
基于Java实现的一层简单人工神经网络算法示例
后端开发2023-05-30
简单介绍SORT跟踪算法及其Python实现示例
后端开发2024-01-24
Python实现的文本简单可逆加密算法示例
后端开发2022-06-04
java实现Floyd算法的示例
后端开发2023-05-30
咦!没有更多了?去看看其它编程学习网 内容吧