热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

约瑟夫环基本版(java)

约瑟夫环基本版(java)问题描述部分代码讲解预先准备while循环讲解完整代码运行结果代码不是本人自己所写,是在一本书上看到的ÿ

约瑟夫环基本版(java)

  • 问题描述
  • 部分代码讲解
    • 预先准备
    • while循环讲解
  • 完整代码
  • 运行结果




代码不是本人自己所写,是在一本书上看到的,经过了一些改正,但是感觉很好,所以想分享一下
问题描述

问题描述:N个人围成一圈,从第M个人开始报数,报到K的人出圈,剩下的人继续从1开始报数,报到K的人出圈;如此往复,直到所有人出圈。(模拟此过程,输出出圈的人的序号)
在这里插入图片描述
以图片为例:
5人围圈,报到3则出局。
第一轮报数

所报数字人的编码
11
22
33(出局)

第二轮报数

所报数字人的编码
14
25
31(出局)

部分代码讲解

预先准备


  • 定义数组

int[] ia=new int[N]; Arrays.fill(ia, 1); //将数组都=1

定义一个数组,并将数组所有内容=1,在循环时,每当出局一人则将该人的赋值=0,详细原因请见while循环的讲解

  • count

int count=0;

记录人数,当所有人全部出局时,结束循环

while循环讲解

while (count<&#61;N) { //见讲解一int j&#61;0; while (true) {j&#61;j&#43;ia[i];if (j&#61;&#61;K) {ia[i]&#61;0;if (i&#61;&#61;0) {System.out.print((i&#43;ia.length)&#43;"\t");}else {System.out.print(i&#43;"\t");}count&#43;&#43;;break;}if (i&#61;&#61;ia.length-1) {i&#61;0;}else {i&#43;&#43;;}} }

  • 讲解一&#xff1a;while循环

while (count<&#61;N) { while (true) {}
}

外层循环&#xff1a;count纪录出局人数&#xff0c;N是总共的人数&#xff0c;当count>N时结束循环
内层循环&#xff1a;一个无限循环&#xff0c;再循环内设置了一个break来结束循环

  • 讲解二&#xff1a;if讲解

if (j&#61;&#61;K) {ia[i]&#61;0;if (i&#61;&#61;0) {System.out.print((i&#43;ia.length)&#43;"\t");}else {System.out.print(i&#43;"\t");}count&#43;&#43;;break;}

外层if&#xff1a;K表示钥匙&#xff08;每报到3的人出局&#xff09;&#xff0c;当 j 与K相等时进入循环&#xff0c;即有 a[i] 出局
内层if&#xff1a;由于数组下标是从零开始的&#xff0c;所以我们将 i&#61;0 的时候定义成最后一个数 &#xff08;如图&#xff09;&#xff0c;当是其他数时&#xff0c;直接输出即可。
在这里插入图片描述

if (i&#61;&#61;ia.length-1) {i&#61;0;}else {i&#43;&#43;;}

由于数组是一个单向的&#xff0c;所以当循环到数组的最后一个数时&#xff0c;需要将其更改到第一个

完整代码

import java.util.Arrays;
import java.util.Scanner;public class Joseph {public static void main(String[] args) {Scanner sc&#61;new Scanner(System.in);System.out.print("围桌座的人数&#xff1a;");int N&#61;sc.nextInt(); //人数System.out.print("从几号开始报数&#xff1a;");int M&#61;sc.nextInt(); //开始报号的人System.out.print("钥匙是&#xff1a;");int K&#61;sc.nextInt(); //钥匙int[] ia&#61;new int[N]; Arrays.fill(ia, 1); //将数组都&#61;1int count&#61;0; //记录出局人数int i&#61;M; //利用while循环出局&#xff0c;每次while循环一次都会有一个人出局 while (count<&#61;N) {int j&#61;0; while (true) {j&#61;j&#43;ia[i];if (j&#61;&#61;K) {ia[i]&#61;0;if (i&#61;&#61;0) {System.out.print((i&#43;ia.length)&#43;"\t");}else {System.out.print(i&#43;"\t");}count&#43;&#43;;break;}if (i&#61;&#61;ia.length-1) {i&#61;0;}else {i&#43;&#43;;}} }}
}

运行结果

在这里插入图片描述


推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了在Java中gt、gtgt、gtgtgt和lt之间的区别。通过解释符号的含义和使用例子,帮助读者理解这些符号在二进制表示和移位操作中的作用。同时,文章还提到了负数的补码表示和移位操作的限制。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 关键词:Golang, Cookie, 跟踪位置, net/http/cookiejar, package main, golang.org/x/net/publicsuffix, io/ioutil, log, net/http, net/http/cookiejar ... [详细]
author-avatar
我摸你马匹
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有