您好,欢迎来到画鸵萌宠网。
搜索
您的当前位置:首页数据结构约瑟夫环

数据结构约瑟夫环

来源:画鸵萌宠网


任务描述

本关任务:n个人围成一圈,按顺序从1到n进行编号,初始时从编号为1的人开始按1、2、3…顺序报数,报数到m(1≤m≤n)时该人退出到圈外,接着从出圈时的下一个位置开始从1开始重新进行报数,报数到m时的人再退出到圈外,以此类推。

编程要求

根据提示,在右侧编辑器补充代码,补充完成函数void Jesuphus(LinkNode *&L, int n, int m),其中L为不带附加头结点的循环单链表的头指针,n为圈中人的个数,m为报数的值。

各种格式

输入格式
输入只有一行,为n和m。1≤n≤3000,1≤m≤n。

输出格式
输出包含一行,为退出到圈外的人的编号,编号之间以一个空格分隔。

样例输入1
10 3

样例输出1
3 6 9 2 7 1 8 5 10 4

样例输入2
7 4

样例输出1
4 1 6 5 7 3 2

开始你的任务吧,祝你成功!

C++代码

#include "linklist.h"

/**
 * 约瑟夫环:L为不带附带头结点的循环单链表的头指针
 */
void Jesuphus(LinkNode *&L, int n, int m)
{
	//请在下面编写代码
	/******************Begin******************/
    int count=0;
    int i=2;
    LinkNode *pre=L,*p=pre->next;
    while(count!=n){
        if(m==1)
    {
        for(int i=1; i<=n; i++)
        {
            printf("%d ",i);
        }
        return;
    }
    if(i==m)
    {
        printf("%d ",p->data);
        pre->next=p->next;
        free(p);
        p=pre->next;
        i=1;
        count++;
    }
    else
    {
        pre=p;
        p=p->next;
        i++;
    }
}
	/*******************End*******************/
}

//尾插法建立循环单链表
void CreateListR(LinkNode *&L, ElemType a[], int n)
{
	LinkNode *s, *r;
	L = (LinkNode *)malloc(sizeof(LinkNode));  	//创建头结点
	L->data = a[0];
	L->next = NULL;
	r = L;					//r始终指向终端结点,开始时指向头结点
	for (int i = 1; i < n; i++)
	{
		s = (LinkNode *)malloc(sizeof(LinkNode)); //创建新结点s
		s->data = a[i];
		r->next = s;		//将结点s插入结点r之后
		r = s;
	}
	r->next = L;			//形成循环单链表
}

//输出循环单链表
void DispList(LinkNode *L)
{
	LinkNode *p = L;
	while (p->next != L)
	{
		printf("%d ", p->data);
		p = p->next;
	}
	printf("%d\n", p->data); //打印最后一个结点的值
}

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- huatuo8.com 版权所有 湘ICP备2023022238号-1

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务