你的位置:首页 > 信息动态 > 新闻中心
信息动态
联系我们

1.双向链表

2021/12/19 22:30:58

 

7-9 约瑟夫问题变形

编号为1…N的N个小朋友玩游戏,他们按编号顺时针围成一圈,按顺时针次序报数,从第1个人报到第M个人出列;然后再从下个人开始报到第M+1个人出列;再从下一个人开始报到第M+2个人出列……以此类推不断循环,直至最后一人出列。请编写程序按顺序输出出列人的编号。 

pic.jpg

输入格式:

输入为2个整数,分别表示N、M(1≤N,M,K≤10000)。

输出格式:

输出为一行整数,为出列人的编号。每个整数后一个空格。

输入样例1:

6 3

结尾无空行

输出样例1:

3 1 2 6 4 5 

结尾无空行

输入样例2:

10 2

结尾无空行

输出样例2:

2 5 9 6 4 8 7 3 1 10 

结尾无空行

输入样例3:

5 1

结尾无空行

输出样例3:

1 3 2 5 4 

结尾无空行

 

#include<stdio.h>
#include<malloc.h>
typedef struct Link
{
	int data;
	struct Link *next;
	struct Link *pre;
}*link;
void create(link head,int n)
{
	link p,r;
	int i;
	p=head;
	for(i=1;i<=n;i++)
	{
		r=(link)malloc(sizeof(link));
		r->next =NULL;
		r->pre =NULL;
		r->data =i;
		p->next =r;
		r->pre =p;
		p=r;
	}
	head->next->pre =p;
	p->next=head->next;
}
void delete(int m,int n,link head)
{
	int i,k,x=0;
	link q,p;
	p=head->next;
	for(k=1,i=1;;i++)
	{
		if(k<=m-1)
		{
			p=p->next;
			k++;
		}
		if(k==m)
		{
			printf("%d ",p->data);
			x++;
			p->pre->next=p->next ;
			p->next->pre=p->pre ;
			q=p;
            p=p->next;
			free(q);
			k=1;
			m=m+1;
		}
		if(x==n)
		{
			break;
		}
	}
}
int main()
{
	int n,m;
	link head;
	head=(link)malloc(sizeof(link));
	head->next =NULL;
	head->pre =NULL;
	scanf("%d%d",&n,&m);
	create(head,n);
	delete(m,n,head);
	return 0;
 }