早教吧 育儿知识 作业答案 考试题库 百科 知识分享

约瑟夫环问题解答。需要算法和数据结构1.约瑟夫环问题[问题描述]设有n个人围坐一圈,现从第s个人开始报数,数到m的人出列,接着从出列的下一个人开始重新报数,数到m的人又出列。

题目详情
约瑟夫环问题解答。
需要算法和数据结构
1.约瑟夫环问题
[问题描述] 设有n个人围坐一圈,现从第s个人开始报数,数到m的人出列,接着从出列的下一个人开始重新报数,数到m的人又出列。如此下去,直到所有人都出列为止。试设计确定他们出列次序序列的程序。
[基本要求] 选择单向循环链表作为存储结构模拟整个过程,并依次输出出列的各人的编号。
[实现提示] 此题中循环链表可不设头结点,而且必须注意空表和“非空表”的界限。如:n=8,m=4时,若从第一个人开始报数,设每个人的编号依次为1,2,3,…开始报数,则得到的出列次序为4 8 5 2 1 3 7 6,如下图所示,内层数字表示人的编号,每个编号外层的数字代表人出列的序号。
▼优质解答
答案和解析
#define N 100
int yuesefu1(int data[],int sum,int k)
{
int i=0,j=0,count=0;
while(count{
if(data[i]!=0)/*当前人在圈子里*/
j++;
if(j==k)/*若该人应该退出圈子*/
{
data[i]=0;/*0表示不在圈子里*/
count++;/*退出的人数加1*/
j=0;/*重新数数*/
}
i++;/*判断下一个人*/
if(i==sum)/*围成一圈*/
i=0;
}
for(i=0;iif(data[i]!=0)
return data[i];/*返回最后一个人的编号*/
}
void main()
{
int data[N];
int i,j,total,k;
printf("\nPlease input the number of every people.\n");
for(i=0;i{
int input;
scanf("%d",&input);
if(input==0)
break;/*0表示输入结束*/
for(j=0;jif(data[j]==input)
break;
if(j>=i&&input>0)/*无重复,记录编号,继续输入*/
{
data[i]=input;
i++;
}
else
printf("\nData error.Re-input:");
}
total=i;
printf("\nYou have input:\n");
for(i=0;i{
if(i%10==0)
printf("\n");
printf("%4d",data[i]);
}
printf("\nPlease input a number to count:");
scanf("%d",&k);
printf("\nThe last one's number is %d",yuesefu1(data,total,k));
}
.
看了约瑟夫环问题解答。需要算法和数...的网友还看了以下:

在频数分布直方图中()A.横轴必须从0开始,纵轴不受这个限制B.纵轴必须从0开始,横轴不受这个限制  2020-04-08 …

在频数分布直方图中()A.横轴必须从0开始,纵轴不受这个限制B.纵轴必须从0开始,横轴不受这个限制  2020-04-08 …

甲、乙两人的房子相距280米,有一天,甲、乙两人在同一时间出门拜访对方.甲每分钟走60米,乙每分钟  2020-06-03 …

.不符合原始凭证基本要求的是()。A.从个人取得的原始凭证,必须有填制人员的签名盖章B.原始凭证不  2020-06-20 …

下列说法正确的是()A.当女性的一侧输卵管堵塞后,肯定就不能怀孕了B.婴儿出生是一个新生命的开始C  2020-06-25 …

“一切从零开始,从乡“一切从零开始,从乡村开始,从识字和算术开始.别人离开的时候,她留下来;别人收  2020-06-28 …

如图为子宫中的胎儿示意图,请据图回答:(1)胚胎发育是从开始的.胚胎在母体子宫内发育的时间约为周.  2020-07-29 …

在条形统计图上()A.横轴必须从0开始,纵轴不受任何限制B.纵轴必须从0开始,横轴不受任何限制C.  2020-07-30 …

宋代,儒学家开始从一个新的角度来思考人间的伦理纲常。这个新的角度是()A.从矛盾对立转换出发B.从天  2020-11-14 …

下列说法正确的是()A.受精卵的形成是一个新生命的开始B.人们常说的“十月怀胎,一朝分娩”,是说胎儿  2020-12-02 …