【算法实现】josephus problem

josephus problem:
n个人围成一圈,1、2、1、2报数,数到2的人被杀,最后留下的人生存,如何找到一个位置是自己生存。

下面一个好玩儿的程序可以解决josephus problem,并扩展为逢q杀,enjoy it:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int ceiling(int divident, int divisor)
  4. {
  5.     if ((divident % divisor) == 0)
  6.         return divident / divisor;
  7.     else
  8.         return (divident / divisor) + 1;
  9. }

  10. int main(int argc, char *argv[])
  11. {
  12.     if (argc < 3) {
  13.         printf("usage: %s <参与人数> <数到几的人被杀>/n", argv[0]);
  14.         return -1;
  15.     }
  16.     int d = 1;
  17.     int n = atoi(argv[1]);
  18.     int q = atoi(argv[2]);
  19.     while (d <= (q - 1) * n) {
  20.         d = ceiling(q*d, q-1);
  21.     }
  22.     int serviver = q * n + 1 - d;
  23.     printf("一共%d个人参加, 每次数到%d的人被杀/n", n, q);
  24.     printf("最开始站在第%d个位置,能最终避免被杀/n", serviver);
  25.     return 0;
  26. }

原理与分析请见《具体数学》第三章第三节,我只是小小的实现了一下其中的结论,改天再补下原理部分好了,不得不佩服数学的伟大啊。

嘿嘿,谁来跟我玩儿这个游戏啊?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值