7.23(游戏:储物柜难题)一个学校有100个储物柜和100个学生。所有的储物柜在上学的第一天都是关着的。…在所有学生都经过教学楼并且改变柜子之后,哪些柜子是开着的?
题目
题目描述
7.23(游戏:储物柜难题)一个学校有100个储物柜和100个学生。所有的储物柜在上学的第一天都是关着的。
随着学生进入,第一个学生S1打开了每个柜子
第二个学生S2从第二个柜子L2开始,关闭相隔1的柜子
学生3(S3)从第三个柜子L3改变每第三个柜子的状态(关闭改打开,打开改关闭)
S4从L4开始改变每第4个柜子状态
S5从L5开始改变每第5个柜子状态
……
S100改变L100为止
在所有学生都经过教学楼并且改变柜子之后,哪些柜子是开着的?显示所有打开的储物柜号,以一个空格隔开
提示:使用包含100个布尔型元素的数组,每个元素都表明一个柜子是开的(true)还是关的(false)。初始都是关的
破题
- 主方法:声明一个长度为100的boolean型数组(默认值false)
- 主方法:上述第i个同学从第i个柜子开始改变每i个柜子状态,即用for循环遍历boolean型数组,调用自定义方法,传入boolean数组和遍历的次数,用原数组对象接收方法返回值
- 主方法:上述操作结束后,对数组再进行遍历,当元素值为true,则返回index下标值+一个空格
- 自定义方法:创建一个值为100的int型对象
- 自定义方法:(假设传入的数组为list,值为num)对传入的数组进行遍历(i从1开始,下标为i-1),凡是i%num==0的,则修改boolean值
- 自定义方法:返回原数组
代码
public class Test7_23 {
public static void main(String[]