数组小练习

痴心易碎 提交于 2019-11-27 13:19:06

 

 //500个人手拉手围一圈,数3退1,直到还剩一个人,找出最后一个人的位置

 

//500个人手拉手围一圈,数3退1,直到还剩一个人,找出最后一个人的位置

//初始化数组

public class Count3Quit2 {
	public static void main(String[] args) {
		boolean [] arr = new boolean[500];
		for(int i = 0;i<arr.length;i++) {
			arr[i] = true;
		}
		
		int CountNum = 0;
		int index = 0;
		int leftCount = arr.length;
		
		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.print(i);
			}
			
		}
		

		
	}
}

 面向对象写法

//500个人手拉手围一圈,数3退1,直到还剩一个人,找出最后一个人的位置
public class Count3Quit3 {
	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 --;
	}
	
}

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!