| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 504 人关注过本帖
标题:[求助]今天做一道约瑟夫环问题,经编译后没有错误.可运行不出来.哪里错了?
取消只看楼主 加入收藏
sdzhuxudong
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2006-9-20
结帖率:0
收藏
 问题点数:0 回复次数:0 
[求助]今天做一道约瑟夫环问题,经编译后没有错误.可运行不出来.哪里错了?

今天做一道约瑟夫环问题经编译后没有错误.可就是运行不出来.请高手指教.谢谢


题目:
编序为1,2,...n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数),一开始人选一个整数作为报数上限m,从第一个人开始按顺时针方向从自1开始顺序报数,报到m时停止报数.报m的人出列,将他的密码作为新的m值,从他的顺时针方向上的下一个人开始从1报数,如此下去,知道所有人全部出列为止,设计一个程序求出出列顺序.
采用单循环链表模拟此程序,按照出列的顺序印出各人的编号

#include<stdio.h>
#include<stdlib.h>
int M,N;
#define NULL 0
struct person
{
int data;
int code;
struct person *next;
};
//创建链表
struct person *create(int n)
{
struct person *p1,*p2,*head;
int i;
p1=p2=(struct person*)malloc(sizeof(struct person));
head=p1;
p1->data=1;
p1->code=rand();
p1->next=NULL;
for(i=2;i<=N;i++)
{
p1=(struct person*)malloc(sizeof(struct person));
p1->data=i;
p1->code=rand();
p2->next=p1;
p2=p1;
}
return (head);
}

//查找从下一个开始第m个节点
struct person *find(struct person *head,int m)
{
struct person *p1,*p2;
int i;
p1=head;
for(i=1;i<=m;i++)
{p2=p1;
if(p1->next=NULL)
p1->next=head;
p1=p1->next;

}
return(p1);
}
//删除p后一个节点并释放节点
void dele(struct person *head,struct person *p)
{
p->next=p->next->next;
free(p->next);
}
//输出链表
void print(struct person *head)
{
struct person *p=head;
do
{
printf("%6d号,密码%6d\n",p->data,p->code);
p=p->next;
}while(p);
}


//约瑟夫环问题
void main()
{struct person *head,*p;
int i=0;
printf("输入人数N:");
scanf("%d",&N);
printf("\n输入第一次报数M:");
scanf("%d",&M);
printf("\n");
head=create(N);
print(head);
//第一次查找删除
p=find(head,M-2);//从第一个查起,查找第m-1个
printf("第1次出局的是%d号.\n",p->next->data);
M=p->next->code;
dele(head,p);//删除第m-1的下一个节点
head=p->next;
//第二次及以后查找删除
while(head!=NULL)
{ p=find(head,M-1);//从下一个查起,查找第m-1个
i++;
printf("第%d次出局的是%d号.\n",i,p->next->data);
M=p->next->code;
dele(head,p);//删除第m-1的下一个节点
head=p->next;
}
}

搜索更多相关主题的帖子: 约瑟夫 编译 运行 
2006-09-24 13:20
快速回复:[求助]今天做一道约瑟夫环问题,经编译后没有错误.可运行不出来.哪里错 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016673 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved