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

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

帮我算一下这道费脑筋的计算题!有4个人在晚上过一座桥,只有一盏灯,这盏等职能耐17分钟,一个人需要  2020-04-07 …

语文好的请进1.将下列八个字分别组合成四个字写在()中言大禽化口革敬田()2.下面这副对联该怎样读  2020-06-13 …

阅读下面两首诗,完成以下小题。(7分)论诗绝句三十首(选二)金·元好问第十二首望帝春心托杜鹃,佳人  2020-06-17 …

一道阅读题,在线等啊现代原子物理学的奠基人卢瑟福对思考为推崇。一天深夜,他偶然发现一位学生还在埋头  2020-07-06 …

冬天到了!春天还会远吗?这句话出自英国著名浪漫主义诗人雪莱的《西风颂》.当寒冷的冬天来临时,寒风瑟  2020-07-06 …

如果有建议用新材料请挑选一个pattern下去做pullover,如果没有用新材料请直接用现有的材料  2020-11-01 …

四个小朋友各拿一把拖把一起去一个水龙头下洗拖把,每人洗完后就可离开.第一人需6分钟,第二人需4分钟,  2020-11-03 …

四个小朋友各拿一把拖把一起去一个水龙头下洗拖把,每人洗完后就可离开.第一人需6分钟,第二人需4分钟,  2020-11-03 …

写作(满分30分)按下列内容提示,写一篇题目为“人人需要朋友”的短文。人人需要朋友。当你太狂热时,需  2020-11-25 …

高中英语作文250分,谢绝复制按照下列内容提示,写一篇题目为“Everyoneneedsfriend  2020-12-24 …