java实现丢手绢问题_java编程约瑟夫问题实例分析

2023-10-17 13:59

本文主要是介绍java实现丢手绢问题_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);

}

}

结果:

b208a9f9c48b88685df288242ea77c12.png

总结

以上就是本文关于java编程约瑟夫问题实例分析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

这篇关于java实现丢手绢问题_java编程约瑟夫问题实例分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/225851

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd