• 一群猴子排成一圈,按1,2,...,n依次编号


    朋友面试遇到的题,网上大部分都是直接往数组后push的解法,不考虑,下面这个方法看起来很简单,但是我理解不了,有大牛懂得给解释一下

    朋友面试遇到的题,网上大部分都是直接往数组后push的解法,不考虑下面这个方法看起来很简单,但是我理解不了,有大牛懂得给解释一下

    朋友面试遇到的题,网上大部分都是直接往数组后push的解法,不考虑,下面这个方法看起来很简单,但是我理解不了,有大牛懂得给解释一下

    一群猴子排成一圈,按1,2,...,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数,再数到第m只,在把它踢出去...,如此不停的进行下去,直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。

    复制代码
    $s = 0;
    $n = 9;$m = 3;
    for($i=1;$i<=$n;$i++) {
        $s = ($s+$m)%$i;
    }
    echo $s+1 . "<br />";
    复制代码

    It's amazing. but why?

  • 相关阅读:
    Java SE(2)
    Java SE(1)
    第二次作业
    Markdown 进阶
    关于主题
    Markdown入门指南
    网络游戏架构与微服务架构简单对比
    微服务框架的存储架构
    轻量级微服务框架的通信架构
    页面静态化
  • 原文地址:https://www.cnblogs.com/gyrgyr/p/8674931.html
Copyright © 2020-2023  润新知