| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1741 人关注过本帖
标题:[求助] C程序的约瑟夫问题,编译成功,运行不成功
取消只看楼主 加入收藏
jianfeng
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2006-11-20
收藏
 问题点数:0 回复次数:1 
[求助] C程序的约瑟夫问题,编译成功,运行不成功

问题:有一组人围成一个圈,分别编号(如1,2,3...),设定一个数K,从编号为K的人开始报数,报到M的出列,然后M的下一位从1开始重新报数,报到M的人出列,直到所有的人全出列,记录出列人的编号.
思路:先构建一个循环链表,再用删除的方法一个一个除去.
代码如下:
#include<malloc.h>
#define NULL 0
typedef struct Node /*定义一个结构体变量*/
{
int data;
struct Node *next;
}Lnode,*LinkList;

LinkList Creat_LinkList(int n) /*创建单循环链表的函数*/
{ /*10*/
int x;
LinkList L;
Lnode *s,*r;
L=r=NULL;
for(x=1;x<=n;x++)
{
s=(Lnode *)malloc(sizeof(Lnode));
s->data=x;
if(L==NULL)
L=s; /*20*/
else
r->next=s;
r=s;
}
if(r!=NULL)
r->next=L;
return L;
}

Lnode *Get_LinkList(LinkList L,Lnode *p)/*30*/ /*寻找指针函数*/
{
Lnode *p2;
p2=L;
while(p2->next!=p)
{
p2=p2->next;
}
return p2;
}
/*40*/
Lnode *Del_LinkList(Lnode *p,LinkList L) /*删除函数*/
{
Lnode *p1;
p1=Get_LinkList(L,p);
p1->next=p->next;
return p1+1;
}

main() /*主函数入口点*/
{ /*50*/
int k,n,m;
LinkList H;
Lnode *p,*w;
printf("Please insert n,k,m:");
scanf("%d%d%d",&n,&k,&m);
H=Creat_LinkList(n);
for(w=H+k;w+1!=w;)
{
printf("%d",w->data);
w=Del_LinkList(w,H);
w=w+m-1;
}
printf("%d",w->data);
getch();
}
编译成功,但运行后不是预期效果.
请高人帮忙看下.

搜索更多相关主题的帖子: 约瑟夫 链表 编译 Node 
2007-03-15 15:21
jianfeng
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2006-11-20
收藏
得分:0 

谢谢大家了,Ashley说得没错,但用的好像还是那个建链表的,我自己调试的时候一到那里就有错了,输出的数字中,两个相邻的总有个9,如:1 9 2 9 3 9 4 9 5 9 6 9.。。。。。读Ashley的程序还真有点绕,哈哈

2007-03-16 23:01
快速回复:[求助] C程序的约瑟夫问题,编译成功,运行不成功
数据加载中...
 
   



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

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