约瑟夫环js的一种实现方式

约瑟夫环的情景问题

  1. 100个人分别编号1~100
  2. 循环报数1、2、3 ,报数3的人排出
  3. 第100号(报数1)结束后,龙摆尾继续报数2、3
  4. 直至剩余最后一个人,求最后一个人的编号
// sum代表多少个人,score代表报什么数组排除
function ring (sum,  score) {
      var numbers = [];
      for (var i = 1; i <= sum; i++) {
        numbers.push(i);
      }
      var flag = 0;
      while (numbers.length > 1) {
        l = numbers.length;
        for (var j = 0; j < l; j++) {
          flag++;
          // 为3时,用splice方法从numbers数组中去掉,改变元数组 
          // 因原数组长度-1,所以索引-1,循环的长度-1
          // 当编号为100时,flag = 1,重新开始报数是1的flag为2,解决的龙摆尾报数的问题
          if (flag == score) {
            flag = 0;
            numbers.splice(j, 1); 
            j--;
            l--;
          }
        }
      }
      return numbers[0];
    };
ring(100, 3) // 91
ring(100, 5) // 47
ring(200, 3) // 128
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值