约瑟夫环(深圳大学oj题目)(适合初学者的讲解方式)


题目描述
有n个人围成一个圈,从第一个人开始顺序报号1,2,3。凡是报到
3退出圈子中的人原来的序号。要求打印出退出人的序号。以及找出
最后留在圈子中的人原来的序号。

输入
n

输出
退出人的序号,并找出最后留在圈子里的人原来的序号

样例输入
13

样例输出
3 6 9 12 2 7 11 4 10 5 1 8 13


读题分析出要实现的功能开始建模:
1:有n个人围成一个圈,既要实现循环报数。
2:从第一个人开始顺序报号1,2,3。凡是报到3退出圈子中的人原来的序号。
既要用到一个1,2,3循环的计数器,同时要让数到三的人不在被数到(不一定要
真的将这个数据从数组中删掉)
3:要求打印出退出人的序号。以及找出最后留在圈子中的人原来的序号。既要标
记被数到3的人,或者是将它们 放在 一个新的数组里


功能实现:
1.当数到最后一个人的时候就减去n回到第一个人这样就可以轻松实现循环
2.定义一个计数器 count,用数组序号代表人,用1代表这个人活着,用0代表这个人
死了,当数到这个人的时候 并且确定他是1 活着的时候计数器就加一,每到3就将一个
人改为0,并且计数器减三,并且将这个人的序号放到一 个新的数组中去。
3.一直数直到所有人都为零的时候,才结束跳出,输出新数列中的前n-1即为退出的人
,在输出最后一个,即为活 下来的人。
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值