Java黑皮书课后题第7章:**7.23(游戏:储物柜难题)一个学校有100个储物柜和100个学生。所有的储物柜在上学的第一天都是关着的。…在所有学生都经过教学楼并且改变柜子之后,哪些柜子是开着的?

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)。初始都是关的

破题

  1. 主方法:声明一个长度为100的boolean型数组(默认值false)
  2. 主方法:上述第i个同学从第i个柜子开始改变每i个柜子状态,即用for循环遍历boolean型数组,调用自定义方法,传入boolean数组和遍历的次数,用原数组对象接收方法返回值
  3. 主方法:上述操作结束后,对数组再进行遍历,当元素值为true,则返回index下标值+一个空格
  4. 自定义方法:创建一个值为100的int型对象
  5. 自定义方法:(假设传入的数组为list,值为num)对传入的数组进行遍历(i从1开始,下标为i-1),凡是i%num==0的,则修改boolean值
  6. 自定义方法:返回原数组

代码

public class Test7_23 {
   
    public static void main(String[]
  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值