约瑟夫问题。

约瑟夫问题。有n个人,编号为1,2,…,n,围成一个圆圈,按照顺时针方向从编号为k的人从1开始报数,报数为m的人出列,他的下一个人重新开始从1报数,数到m的人出列,一直这样重复下去,直到所有的人都出列。要求编写一个算法,输入n、k和m,依次输出每次出列人的编号。

算法描述如下:

void Josephus(LinkList h,int n,int m,int k)

/*在由n个人围成的圆圈中,从第k个人开始报数,数到m的人出列*/

{

         ListNode *p,*q;

         int i;

         p=h;

         for(i=1;i<k;i++)           /*从第k个人开始报数*/

         {

                   q=p;

                   p=p->next;

         }

         while(p->next!=p)

         {

                   for(i=1;i<m;i++)         /*数到m的人出列*/

                   {

                            q=p;

                            p=p->next;

                   }

                   q->next=p->next;       /*将p指向的结点删除,即报数为m的人出列*/

                   printf("%4d",p->data);

                   free(p);

                   p=q->next;                           /*p指向下一个结点,重新开始报数*/

         }

         printf("%4d\n",p->data);

}

测试代码由自己编写,或参考零基础学数据结构,机工社,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值