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

约瑟夫环问题解答。需要算法和数据结构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));
}
.
看了约瑟夫环问题解答。需要算法和数...的网友还看了以下:

小聪6:00出门,看了一下手表,时针和分针在同一直线上,且方向相反,小聪回到家中又看了一下表,此时  2020-04-09 …

小聪6:00出门,看了一下手表,时针和分针在同一直线上,且方向相反,小聪回到家中又看了一下表,此时  2020-04-09 …

⒈奇奇和丢丢骑自行车从学校出发到历史博物馆参观,出发前他两一起算了一下:如果每小时骑10Km,上午  2020-05-17 …

甲乙两堆沙子,第一次从甲堆取出和乙堆一样多的沙子放到乙堆,第二次从乙堆取出和甲堆剩下的同样多的沙子  2020-06-12 …

有甲、乙两队棋子,其中甲堆棋子多于乙堆.现在按如下方法移动棋子:第一次从甲堆中拿出和乙堆一样多的棋  2020-06-16 …

甲、乙两堆小球各有若干个,按下面的规则移动小球:第一次从甲堆拿出和乙堆同样多的小球放到乙堆;第二次  2020-06-25 …

题来了:小明下午五点多有事外出时,看到墙上钟面的时针和分针的夹角为110°,下午不到六点回家时,发  2020-07-18 …

有甲、乙两个港口,各停小船若干只,如果按下面的规则移动船只:第一次从甲港开出和乙港同样多的船只到乙港  2020-11-04 …

是谁坐了马车?一个年轻人和一个中年人同时从乡下出发到城里,一个坐马车,一个坐汽车,他们在走了一段路后  2020-12-03 …

什么是表示时间跨度的词语?请举例说明.RT、、“很早”“流传下来”和“到了现代”哪一个是?  2020-12-20 …