PHP演算法之猴子選大王的遊戲

來源:互聯網
上載者:User
猴子選大王遊戲

一群猴子排成一圈.按1,2,...,n依次排號.

然後從第一隻開始數,數到第m只,把它踢出圈,從它後面再開始數.

再數到第m只,把它踢出去..如此不停的進行下去.

直到最後只剩下一隻猴子為止,那隻猴子就叫大王.

要求編程類比此過程,輸入m,n. 輸出最後那個大王的編號.
  1. function monkeyKing($n, $m) {
  2.         $monkeys = range(1, $n);
  3.         $i = 0;                // 取出時候的座標
  4.         $z = 0;                // 數到M的時候停
  5.         while(($mNum = count($monkeys)) > 1) {
  6.                 if($i == $mNum) {
  7.                         $i = 0;                // 圈
  8.                 }
  9.                 $z++;
  10.                 $i++;
  11.                 if($z == $m) {
  12.                         array_splice($monkeys, --$i, 1);
  13.                         $z = 0;                // 歸零
  14.                 }
  15.         }
  16.         return($monkeys[0]);
  17. }

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.