Josephus问题Java实现
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实现的更多相关文章
- 约瑟夫环 --- 面向对象 --- java代码
约瑟夫环 的 面向对象 解法 罗马人占领乔塔帕特后,39个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,由第1个 ...
- 算法Sedgewick第四版-第1章基础-017一约瑟夫问题(Josephus Problem)
/************************************************************************* * * Josephus problem * * ...
- Spark案例分析
一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...
- Josephus环类问题,java实现
写出一个双向的循环链表,弄一个计数器,我定义的是到三的时候,自动删除当前节点,很简单. package Com; import java.util.Scanner; /* * 约瑟夫环问题,有n个人组 ...
- Josephus问题的java实现
import java.util.ArrayList; import java.util.ListIterator; public class Josephus { public static voi ...
- Josephus Problem的详细算法及其Python、Java实现
笔者昨天看电视,偶尔看到一集讲述古罗马人与犹太人的战争--马萨达战争,深为震撼,有兴趣的同学可以移步:http://finance.ifeng.com/a/20170627/15491157_0. ...
- [Java]使用队列求解josephus问题
约瑟夫斯问题(有时也称为约瑟夫斯置换),是一个出现在计算机科学和数学中的问题.在计算机编程的算法中,类似问题又称为约瑟夫环. 有个囚犯站成一个圆圈,准备处决.首先从一个人开始,越过个人(因为第一个人已 ...
- Java实现约瑟夫环
什么是约瑟夫环呢? 约瑟夫环是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围.从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个 ...
- 约瑟夫问题(java实现)
方法一.自定义的链表实现 package com.code.yuesefu; public class YueSeFuList { public static void main(String[] a ...
随机推荐
- JAVA面试常见问题之常见集合篇
1.List 和 Set 区别 List 可以允许重复的对象. 可以插入多个null元素. 有序容器 Set 不允许重复的对象. 只能插入1个null元素 无序容器,可以使用TreeSet实现有序 2 ...
- H5C3--边框图片
类似于android的.9图片,目的是为了防止图片因为内容的扩展而导致图片拉伸失真. <!DOCTYPE html> <html lang="en"> &l ...
- java 判断数据类型和方法
java 判断数据类型和方法 .我从SOLR查询中获取一个数据一,已知数据类型,是string或者int 或者其他 .我有一个方法(set方法),只有一个参数,但是我不知道参数的数据类型,可能是str ...
- 读书笔记--Head First C#目录
1.c#助你快速开发2.都只是代码3.对象4.类型与引用5.封装6.继承7.接口与抽象类8.枚举与集合9.读/写文件10.异常处理11.事件与委托12.复习与预习13.控件与图片14.captain ...
- angular4 Form表单相关
ng4中,有两种方式去声明一个表单 一:Template-Driven Forms - 模板驱动式表单 [引入FormsModule] 1.ngForm赋值 [可以方便的获取表单的值] <f ...
- ZooKeeper的分布式锁实现
分布式锁一般有三种实现方式: 1. 数据库乐观锁: 2. 基于Redis的分布式锁: 3. 基于ZooKeeper的分布式锁. 本篇博客将介绍第三种方式,基于Zookeeper实现分布式锁.虽然网上已 ...
- python 下载安装及运行环境配置(windows)
第一步:下载python安装包 下载地址:https://www.python.org/downloads/windows/ 我下载的是版本:3.6.4 安装包下载完成后,点击进行安装. 第二步:配置 ...
- 使用FastJson对实体类和Json还有JSONObject之间的转换
1. 实体类或集合转JSON串 String jsonString = JSONObject.toJSONString(实体类); 2.JSON串转JSONObject JSONObject json ...
- spring拦截器Interceptor
在Spring Boot中,拦截器可以分为两种类型: 一是WebMVC,负责拦截请求,类似于过滤器,对用户的请求在Controller接收前进行处理,在Controller处理完成后加工结果等.使用时 ...
- php手册常用的函数
<?php ************************************************************/ header("Content-type:tex ...