【J2SE】数组学习小实验-数三退一

2024-02-11 04:38

本文主要是介绍【J2SE】数组学习小实验-数三退一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

说明

  • 对于JAVA中一维数组的应用可以用下面的一个算法-数三退一来进行学习,即给定一个上限数,然后从零开始数,每数三下,那么第三个数则退出该数群,则最后一个剩下的数排在原来数群的哪一位?

代码

  • 代码实现如下:
/*
方法一:面向过程的实现:
*/public class Count3Quit {public static void main(String[] args) {boolean[] arr = new boolean[500];for (int i = 0; i<arr.length; i++) {arr[i] = true;}   //计算圈儿里还有多少人int leftCount = arr.length;//模拟计数器,每看到一个人就加一int countNum = 0;//数到第几个了int index = 0;while(leftCount > 1) {if(arr[index] == true) {countNum ++;if(countNum == 3) {countNum = 0;arr[index] = false;leftCount --;}}index ++;if(index == arr.length) {index = 0;}}for(int i = 0; i < arr.length; i++) {if(arr[i] == true) {System.out.println(i);}}}
}
/* 方法二:面向对象的实现 */public class Count3Quit2 {public static void main(String[] args) {KidCircle kc = new KidCircle(500);int countNum = 0;Kid k = kc.first;while(kc.count > 1) {countNum ++;if(countNum == 3) {countNum = 0;kc.delete(k);}k = k.right;}System.out.println(kc.first.id);}
}class Kid {int id;Kid left;Kid right;
}class KidCircle {int count = 0;Kid first,last;//多少人的圈KidCircle(int n) {for(int i = 0; i < n; i++) {add();}}//添加小孩void add() {Kid k = new Kid();k.id = count;if(count <= 0) {first = k;last = k;k.left = k;k.right = k;} else {last.right = k;k.left = last;k.right = first;first.left = k;last = k;}count ++;}void delete(Kid k) {if(count <= 0) {return;}else if(count == 1) {first = last = null;}else {k.left.right = k.right;k.right.left = k.left;if(k == first) {first = k.right;}else if(k == last) {last = k.left;}}count --;}
}

总结

  • 对于这个算法的理解就是实现封闭性数组(环状数组)的一个首尾连接的问题,理解起来有一些困难。但是自己写一遍之后就清楚多了。

这篇关于【J2SE】数组学习小实验-数三退一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio