package com.qingfeng;
/**
* @author Administrator
* 功能:约瑟夫问题:
* 设编号分别为:1,2,...,n的n个人围坐一圈。
* 约定序号为k(1 <= k < = n)的人从1开始计数,数到m的那个人出列,
* 他的下一位又从1开始计数,数到m的那个人又出列,依次类推,直到所有人出列为止。
*/
public class Josephus { public static void main(String[] args) {
// TODO Auto-generated method stub
KidLink kid = new KidLink();
kid.setLength(5);
kid.creatLink();
kid.setM(2);
kid.setK(3); kid.show();
kid.play();
}
}
//孩子类
class Kid
{
//成员变量
int no;//孩子编号
Kid nextKid;//下一个孩子的引用 关键点! //构造方法
public Kid(int no)//设置孩子的编号
{
this.no = no;
}
} //孩子环形链表类
class KidLink
{
//成员变量
Kid firstKid;//第一个孩子的引用 不能动!!关键点! int i;
int len;//圈的长度:多少个人 Kid temp;//跑龙套 int m;//约定开始数数的那个人
int k;//约定数几下出圈 //成员方法
//设置循环链表的长度即
public void setLength(int len)
{
this.len = len;
} //1.创建孩子3.连成环状
public void creatLink()
{
for(i=1; i<=len; i++)
{
if(i==1)//第一个孩子
{
Kid ch = new Kid(i);//创建第一个孩子 ch为第一个孩子的引用
firstKid = ch;//firstKid指向第一个孩子!
temp = ch;//跑龙套temp也指向当前孩子!
}
else
{
if(i == len)//最后一个孩子
{
Kid ch = new Kid(i);//创建最后一个孩子
temp.nextKid = ch;
temp = ch;
temp.nextKid = firstKid;
}
else
{
Kid ch = new Kid(i);//创建剩余的孩子
temp.nextKid = ch;//跑龙套(孩子的引用)的下一个孩子(相当于next指针)指向当前 孩子!
temp = ch;//跑龙套指向新的当前孩子!
}
}
}
}
//打印孩子编号即围成的圈
public void show()
{
temp = firstKid;
do{
System.out.print(temp.no+" ");
temp = temp.nextKid;
}while(temp!= firstKid);//理解do while的好处
} //设置m的值
public void setM(int m)
{
this.m = m;
}
//设置n的值
public void setK(int k)
{
this.k = k;
}
//开始玩游戏
public void play()
{
temp = firstKid;
//1.先找到数数的那个人m
for(i=1; i<m; i++)//易错!不是"等于"
{
temp = temp.nextKid;
}
while(len!=1){
System.out.print(" m的值为"+temp.no);
//2.数n下找到出圈的人即temp
for(i=1; i<k; i++)//易错!不是"等于"
{
temp = temp.nextKid;
}
//3.temp退圈
//先找到temp的前一个人即temp2
Kid temp2;
temp2 =temp;
while(temp2.nextKid != temp)
{
temp2 = temp2.nextKid;
}
temp2.nextKid = temp.nextKid; //删除语句 如第二人指向第四个人
System.out.print(" 出圈人"+temp.no);
temp = temp.nextKid;//开始数数的人temp指向被删的下一个 len--;//每次少一个人
}
System.out.println(" 最后出圈的是"+temp.no);
}
}

Josephus问题Java实现的更多相关文章

  1. 约瑟夫环 --- 面向对象 --- java代码

    约瑟夫环 的 面向对象 解法 罗马人占领乔塔帕特后,39个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,由第1个 ...

  2. 算法Sedgewick第四版-第1章基础-017一约瑟夫问题(Josephus Problem)

    /************************************************************************* * * Josephus problem * * ...

  3. Spark案例分析

    一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...

  4. Josephus环类问题,java实现

    写出一个双向的循环链表,弄一个计数器,我定义的是到三的时候,自动删除当前节点,很简单. package Com; import java.util.Scanner; /* * 约瑟夫环问题,有n个人组 ...

  5. Josephus问题的java实现

    import java.util.ArrayList; import java.util.ListIterator; public class Josephus { public static voi ...

  6. Josephus Problem的详细算法及其Python、Java实现

      笔者昨天看电视,偶尔看到一集讲述古罗马人与犹太人的战争--马萨达战争,深为震撼,有兴趣的同学可以移步:http://finance.ifeng.com/a/20170627/15491157_0. ...

  7. [Java]使用队列求解josephus问题

    约瑟夫斯问题(有时也称为约瑟夫斯置换),是一个出现在计算机科学和数学中的问题.在计算机编程的算法中,类似问题又称为约瑟夫环. 有个囚犯站成一个圆圈,准备处决.首先从一个人开始,越过个人(因为第一个人已 ...

  8. Java实现约瑟夫环

    什么是约瑟夫环呢? 约瑟夫环是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围.从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个 ...

  9. 约瑟夫问题(java实现)

    方法一.自定义的链表实现 package com.code.yuesefu; public class YueSeFuList { public static void main(String[] a ...

随机推荐

  1. nginx、php-fpm启动脚本

    Nginx官方启动脚本 //service nginx stop|start|restart|reloadtouch /etc/init.d/nginx chmod nginxvi /etc/init ...

  2. Ubuntu下安装Libpcap

    Libpcap是 Unix/Linux 平台下的网络数据捕获函数包,百度百科是这么说的,唉,不管什么来头,只要帮我完成作业就行,安装过程记录如下: 还是那个套路,先在网上搜了一把,大概也就那样,被疯狂 ...

  3. 中断描述符表 IDT

    保护模式下三个重要的系统表——GDT.LDT和IDT 这里主要是解释中断描述符表 中断描述符表IDT将每个异常或中断向量分别与它们的处理过程联系起来.与GDT和LDT表类似,IDT也是由8字节长描述符 ...

  4. 分布式事务 XA 两段式事务 X/open CAP BASE 一次分清

    分布式事务: 分布式事务是处理多节点上 的数据保持 类似传统 ACID 事物特性的 一种事物. XA:是一种协议,一种分布式事务的协议,核心思想是2段式提交. 1 准备阶段  2 提交阶段.XA协议是 ...

  5. NOIP2017到都不签签记

    day 0: 校内开运动会,但是还是在机房学习了一天. 感觉上并没有多大用处,主要只是活跃一下思维而已. 然后就晚上上车出发去酒店. 下了个游戏王. 晚上叫了波宅急送,然后硬是腐了一个晚上. day ...

  6. linux一些配置的记录

    ssh 登录设置主机的别名 这样不用写那么多东西了 在/etc/ssh/ 下的ssh_config 和 sshd_config 两个文件 前一个是配置客户端的配置文件 另一个是服务器端的配置文件 主要 ...

  7. Python 数据文件操作——写出数据

  8. sqlyog备份数据和导入备份数据

    使用sqlyog备份数据 Database -> Backup/Export  -> Backup Database As SQL Dump 根据自己实际情况,看需要 导出表结构或者仅仅只 ...

  9. mybatis官网文档mybatis_doc

    在平时的学习中,我们可以去参考官网的文档来学习,这个文档有中文的,方便我们去阅读,而且这里的分类很详细. 官网文档链接:http://www.mybatis.org/mybatis-3/zh/inde ...

  10. 【python之路16】作业

    #!usr/bin/env python # -*- coding:utf-8 -*- # 数据库中原有 old_dict = { "#1": {'hostname': 'c1', ...