⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 joseph.txt

📁 数据结构实验指导书中关键算法的C语言实现
💻 TXT
字号:
#define NULL 0
#include"stdio.h"
#include"malloc.h"
#include"string.h"
typedef struct LNode
               {int code;
                int position;
                struct LNode *next;
               }LNode,*LinkList;
int n;
/*尾插法建立单链表,返回表头指针*/
LinkList  CreateList_L(void)
{
	int code;
    	LinkList head,p1,p2;
    	p1=p2=(LinkList)malloc(sizeof(LNode));        /*生成开辟第一个空间*/
    	printf("请输入第1个人的密码");
	scanf("%d",&p1->code);
	p1->position=1;
    	head=NULL;
	while(p1->code!=0)                              /*0为输入结束符*/
    	{	n++;
 		if(n==1) head=p1;
		else p2->next=p1;
                p2=p1;
       		p1=(LinkList)malloc(sizeof(LNode));   /*生成新结点*/
		printf("请输入第%d个人的密码",n+1);
		scanf("%d",&p1->code);/*读下一结点*/
		p1->position=n+1;
       	}
    	p2->next=head;
    	return (head);
}
/*遍历线性表a中的元素*/
/*void output(LinkList head,int n)
{
    	LinkList p,q,k;
    	p=head;
        if(n!=0)
        do
    	{
		printf("%d",p->position);
       		p=p->next;
	}while(--n);
}*/
/*约瑟夫问题求解*/
void JosephSolution(int m,LinkList p1)
{   	LinkList p2;
        while(--m)
	{	p2=p1;
             	p1=p2->next;
	}
	printf("%d,",p1->position);
        p2->next=p1->next;
	if(p2->next!=p2)
	{	JosephSolution(p1->code,p2->next);
		free(p1);
	}
	else {printf("%d",p2->position);free(p2);}
}

main()
{ 	LinkList head;
	int m;
	clrscr();
	head= CreateList_L();
	/*output(head,n);*/
        printf("请输入报数上限值m:");
        scanf("%d",&m);
        printf("出列顺序为:")
        JosephSolution(m,head);

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -