约瑟夫环的数组实现

 约瑟夫(Josephus)问题是由古罗马的史学家约瑟夫提出的,他参加并记录了公元66-70年犹太人反抗罗马的起义。约瑟夫作为一个将军,设法守住了裘达伯特城达47天之久,在城市沦陷之后,他和40名将士在附近的一个洞穴中避难。在哪里,将士们群情激奋并表示:要投降毋宁死。于是,约瑟夫建议每个人轮流杀死他旁边的人,而这个顺序是由抽签决定的。约瑟夫有预谋地抓到了最后一签并且做为洞穴中两个幸存者之一生存下来。

   约瑟夫环问题的具体描述是:设有编号为12......nn(n>0)个人围成一个圈,从第一个人开始报数,报到m时停止报数,报m的人出圈,再从他的下一个人起重新报数,报到m时停止报数,报m的出圈,......,如此下去,知道只剩下一人为止。当任意给定 n m后,设计算法求 n个人出圈的次序。

void  yuesefu(int a[],int n,int m)

{

    int  i = 0,count = 0;                   //count 为被杀的人数

    while (count < n) {

        i -= 1;                                             // i是数组下标,自减后开始数,当数到最后一个时跳到前面

        for (int j = 0; j < m ;j++) {

            if (i == n - count -1) {

                i = -1;

            }

           i++;

        }

        count ++;                                                   //数完一圈后被杀的人加一

        printf("%d     ",a[i]);

        for (int j = i; j < n - count; j++) {               //被杀的人退出去,他后边的人补充他的位置

            a[j] = a[j+1];

        }

    }

}

 

posted @ 2013-09-28 16:01  月影空  阅读(221)  评论(0编辑  收藏  举报