Java编程 数3退1
来源:互联网 发布:上海逸晗网络 编辑:程序博客网 时间:2024/06/07 07:42
数三退一:500个小孩手拉手围成一圈,从第一个小孩开始数数,按照1、2、3、1、2、3循环不断的数,数到3的小孩退出圈,其他小孩接着数,直到剩下一个小孩,问这个小孩的排在什么位置?
<strong>public class Count3Quit1 {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.right = first;k.left = last;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--;}}</strong>
0 0
- Java编程 数3退1
- java 数3退1游戏 实现
- java代码--数3退1
- 数3退1
- 数3退1
- 数3退1
- 数3退1(面向对象思想)
- 链表(数1退3)
- 对像实现数3退1
- 数3退1,数组的环形访问
- JavaSE_28th_数组——数3退1游戏
- 一步一步学习java数组学习(ch5)数3退1记录最后留下来的在队列中的位置
- 【java】逢3退1小练习
- 500个人手拉手,数3退1,求最后一个人原来在那个位置
- PHP数3退1面向对象的写法(猴子选大王)
- java代码for循环实现:500人围成一圈,数3退一,求最后留下的人的最初位置
- java代码while循环实现:500人围成一圈,数3退一,求最后留下的人的最初位置
- java代码面向对象实现:500人围成一圈,数3退一,求最后留下的人的最初位置
- Java实现冒泡排序
- Android的自动锁屏、解锁
- [编程题]合并两个排序的链表
- dp,sp,px的介绍
- 通过R.java文件访问资源
- Java编程 数3退1
- scala-problem36-40
- [LeetCode]299. Bulls and Cows
- hdu2242考研路茫茫——空调教室
- codeforces632d Longest Subsequence(筛选法)
- 你必须非常努力,才能看起来毫不费力!(愿与君共勉)
- LCD1602(程序)
- 利用Json表示Java对象(附利用sublime插件格式化json)
- JavaWeb学习之tomcat服务器下虚拟主机与WEB应用的学习