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 ...
随机推荐
- TZ_09_MyBatis的pageHelper
1.分页操作使用MyBatis的PageHelper 1>导入pageHelper的坐标 <dependency> <groupId>com.github.pagehel ...
- 抓取B站小视频
抓取B站小视频的代码如下: #请求库import requests #请求头部信息(用户代理)headers={ 'User-Agent':'Mozilla/5.0 (Windows NT 6.1; ...
- C++怎么读入非文本文件中的内容
C++怎么读入非文本文件中的内容 3条回答 #include <io.h> #include <windows.h> void main() { char* pFileName ...
- LAMP环境搭建和配置(2)
配置httpd 默认虚拟主机 编辑hpptd的主配置文件 搜索httpd-vhost,把行首的#号删除 保存主配置文件,然后编辑虚拟主机配置文件 重新编辑配置段(第一段为默认虚拟主机) ServerA ...
- mybatis深入理解(一)-----Mybatis初始化机制详解
对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程. 一. MyBatis的初始化做了什么 1.configuration ...
- Intent传递list集合时异常解决
以前只是用intent传递一些简单的值,最近传递list集合时发现值总是传不过去,logcat报如下错误 说的是不能处理值为null的情况,回过头看list集合时确实发现有value为null的key ...
- 引入样式表(css)的四种方式
一.使用style属性: 将style属性直接加在html标签里. <标签 style="属性1: 设定值1; 属性2: 设定值2; "> 例如: <td sty ...
- 阿里云DMS发布数据库网关服务: 打通网络限制 开启数据库统一管理的万能钥匙
概述 阿里云数据管理DMS在云端可提供专业的数据库服务,除对标本地数据库软件的基础功能外,还包含性能诊断.数据追踪.跨实例SQL查询(含异构数据库类型之间)等专业性功能,同时提供审计安全和企业级数据库 ...
- 【Python之路22】冒泡排序算法
1.变量互换 a = 123 b = 456 temp = a a = b b = temp python比较简单的变量互换: a = 123 b = 456 a,b = b,a print(a,b) ...
- CSS Tools: Reset CSS
样式初始化 /* http://meyerweb.com/eric/tools/css/reset/ v2.0 | 20110126 License: none (public domain) */ ...