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

输入格式:
输入为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;
 }  
                