java编程约瑟夫问题实例分析
作者:Mu_TQ 发布时间:2022-04-05 22:32:08
标签:算法,java
一、简介
约瑟夫问题(有时也称为约瑟夫斯置换,是一个出现在计算机科学和数学中的问题。在计算机编程的算法中,类似问题又称为约瑟夫环。又称“丢手绢问题”.)
例子:
len个人围成一个圈,玩丢手绢游戏。从第k个人开始,从1开始数数,当数到m时,数m的人就退出圈子,当圈子只剩下一个人为止。
问题分析与算法设计
约瑟夫问题并不难,但求解的方法很多;题目的变化形式也很多。这里给出一种实现方法。
题目中len个人围成一圈,因而启发我们用一个循环的链来表示,可以使用结构数组来构成一个循环链。结构中有两个成员,其一为指向第一个孩子的头节点,另一个为作为判断的节点temp(负责跑龙套)。
具体代码如下:
package demo11;
/**
* 约瑟夫问题, 化为丢手绢
*
* @author tianq 思路:建立一个Child类 一个循环列表类CyclLink
*/
public class demo11 {
public static void main(String[] args) {
CyclLink cyclink = new CyclLink();
cyclink.setLen(15);
cyclink.createLink();
cyclink.setK(2);
cyclink.setM(2);
cyclink.show();
cyclink.play();
}
}
// 先建立一个孩子类
class Child {
// 孩子的标识
int no;
Child nextChild;
// 指向下一个孩子
public Child(int no) {
// 构造函数给孩子一个id
this.no = no;
}
}
class CyclLink {
// 先定义一个指向链表第一个小孩的引用
// 指向第一个小孩的引用,不能动
Child firstChild = null;
Child temp = null;
int len = 0;
// 表示共有几个小孩
int k = 0;
//开始的孩子
int m = 0;
//数到几推出
// 设置m
public void setM(int m) {
this.m = m;
}
// 设置链表的大小
public void setLen(int len)
{
this.len = len;
}
// 设置从第几个人开始数数
public void setK(int k) {
this.k = k;
}
// 开始play
public void play() {
Child temp = this.firstChild;
// 1.先找到开始数数的人
for (int i = 1; i < k; i++) {
temp = temp.nextChild;
}
while (this.len != 1) {
// 2.数m下
for (int j = 1; j < m; j++) {
temp = temp.nextChild;
}
// 找到要出圈的前一个小孩
Child temp2 = temp;
while (temp2.nextChild != temp) {
temp2 = temp2.nextChild;
}
// 3.将数到m的小孩,退出
temp2.nextChild = temp.nextChild;
// 让temp指向下一个数数的小孩
temp = temp.nextChild;
// this.show();
this.len--;
}
// 最后一个小孩
System.out.println("最后出圈" + temp.no);
}
// 初始化环形链表
public void createLink() {
for (int i = 1; i <= len; i++) {
if (i == 1) {
// 创建第一个小孩
Child ch = new Child(i);
this.firstChild = ch;
this.temp = ch;
} else {
if (i == len) {
// 创建第一个小孩
Child ch = new Child(i);
temp.nextChild = ch;
temp = ch;
temp.nextChild = this.firstChild;
} else {
// 继续创建小孩
Child ch = new Child(i);
temp.nextChild = ch;
temp = ch;
}
}
}
}
// 打印该环形链表
public void show() {
Child temp = this.firstChild;
do {
System.out.print(temp.no + " ");
temp = temp.nextChild;
}
while (temp != this.firstChild);
}
}
结果:
来源:http://blog.csdn.net/tianqingdezhuanlan/article/details/52304263


猜你喜欢
- 写在前面在前后端交互过程中,为了保证信息安全,我们往往需要加点用户验证。本文介绍了用springboot简单整合token。springbo
- 1.什么是mybatis动态sql看到动态,我们就应该想到,这是一个可以变化的sql语句MyBatis的动态SQL是基于OGNL表达式的,它
- 最近学习了一个视频公开课,讲到了利用HorizontalScrollView仿ViewPager设计的一个简单相册,其实主要用了ViewPa
- 最近刚换了电脑,开始搭建Android开发环境的时候,下载SDK总是会出现如下错误:Failed to fetch URL http://d
- 1.java后台(1)使用BigDecimal类方式一:String str=new BigDecimal(num+""
- 简介目的:Optional的出现主要是为了解决null指针问题,也叫NPE(NullPointerException)外形:Optional
- 一:背景1. 讲故事这几天都在修复bug真的太忙了,期间也遇到了一个挺有趣bug,和大家分享一下,这是一块sql挺复杂的报表相关业务,不知道
- 本文实例讲述了Android编程实现分页加载ListView功能。分享给大家供大家参考,具体如下:package eoe.listview;
- 相关文章android popwindow实现左侧弹出菜单层https://www.jb51.net/article/33533.htm移动
- Java 1.0 IO系统介绍1 Java IO版本Java库的IO分为输入/输出两部分。早期的Java 1.0版本的输入系统是InputS
- springboot项目出现”java: 错误: 无效的源发行版:17“问题解决方案下面是报错页面问
- 类和类有关联,将查询的结果注入到对象和对象的关联关系中Mybatis处理的关联关系 包括一对一关联 和 一对多关联 ,例如学生关联班级是一对
- 一、问题描述在C#中is,as,using关键字具有其特点及使用场景,其中is关键字用于检查该对象是否与给定类型兼容,as关键字用于将对象转
- Android activity和view判断滑动 实例代码://手
- 简介本文用示例介绍SpringMVC如何通过JSON格式传递入参。JSON格式使用post方式来请求,即:对应的注解为:@PostMappi
- 常规调用方式:(这个肯定会弹出cmd窗口)Runtime.getRuntime().exec("cmd.exe &nbs
- 本文介绍一些Java初学者常问的问题,可以用%除以一个小数吗? a += b 和 a = a + b 的效果有区别吗? 声明一个数组为什么需
- 本文介绍了android沉浸式状态栏,分享给大家,希望对大家有帮助一、概述现在主流的App设计风格很多都用到了Materail Design
- 前言公众号上有网友询问我如何生成 EMF 文件的问题:本以为非常简单,我快速给出了解决方案:var bitmap = new Bitmap(
- 老规矩,先上图看效果。说明TextView的跑马灯效果也就是指当你只想让TextView单行显示,可是文本内容却又超过一行时,自动从左往右慢