| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 868 人关注过本帖
标题:[讨论]简单的约瑟夫问题
收藏  订阅  推荐  打印 
longfeng867
Rank: 2
来自:重庆
等级:注册会员
威望:1
帖子:178
积分:1900
注册:2007-5-20
[讨论]简单的约瑟夫问题

/*运行环境VC*/
#include <stdio.h>
#include<stdlib.h>
#include <malloc.h>
#define LEN sizeof(struct Joseph)
struct Joseph
{
int num;
struct Joseph *next;
};
int n,s,m;
print(struct Joseph *head) /*打印链对中的信息*/
{
struct Joseph *p;
p=head;
printf("%d个人的代号如下:\n",n);
do
{
printf("%d ",p->num);
p=p->next;
}while(p!=head);
printf("\n");
}
output(struct Joseph *head) /*输出出列情况*/
{
int i,j=1;
struct Joseph *p1,*p2;
p1=p2=head;
for(i=1;i<m;i++)
p1=p1->next;
while(n>0)
{
for(i=1;i<s;i++)
{
p2=p1;
p1=p1->next;
}
printf("第%d个出列的人是:%d\n",j,p1->num);
p2->next=p1->next;
p1=p2->next;
n--;
j++;
}
}
struct Joseph *create() /*建立链队列*/
{
int i;
struct Joseph *head;
struct Joseph *p1,*p2;
printf("请输入总人数(输入0退出程序):\n");
scanf("%d",&n);
if(n==0)
exit(0);//退出
for(i=1;i<=n;i++)
{
p1=(struct Joseph*)malloc(LEN);
p1->num=i;
if(i==1)
head=p1;
else
p2->next=p1;
p2=p1;
}
p2->next=head; /*将整个链队构成一个环形*/
print(head);
printf("请输入从第几个人开始报数:\n");
scanf("%d",&m);
printf("数到第几个人出列:\n");
scanf("%d",&s);
return head;
}
main()
{
struct Joseph *head;
while(1)
{
head=create();
output(head);
system("pause");
system("cls");
}
}
==================================================================================================
大家指点一下...
搜索更多相关主题的帖子: 约瑟夫  讨论  
2007-10-11 18:07
longfeng867
Rank: 2
来自:重庆
等级:注册会员
威望:1
帖子:178
积分:1900
注册:2007-5-20

走过路过,千万不要错过!!!!用心回贴是一种美德!

在这个连处女膜都可以伪造的世界里,还有什么值得我相信!
2007-10-15 10:12
zxc1998
Rank: 2
等级:注册会员
威望:1
帖子:133
积分:1444
注册:2007-3-21

程序基本正确,出队后结点没有释放,这个错误在以后的编程中是很严重的。

2007-10-19 00:06
longfeng867
Rank: 2
来自:重庆
等级:注册会员
威望:1
帖子:178
积分:1900
注册:2007-5-20
回复:(zxc1998)程序基本正确,出队后结点没有释放,...

谢谢你~~以后我会注意的,小程序的不会有多大影响吧~~~


在这个连处女膜都可以伪造的世界里,还有什么值得我相信!
2007-10-19 13:39
柒兲
Rank: 2
等级:注册会员
威望:1
帖子:126
积分:1376
注册:2007-9-26


2007-10-19 15:28
ondy
Rank: 2
等级:注册会员
威望:1
帖子:88
积分:988
注册:2007-9-4

支持!可以用队例做呀


2007-10-22 15:28
nancysawe
Rank: 1
等级:新手上路
帖子:1
积分:110
注册:2008-6-30

可不可以问一下编程心得···

我要写实验报告···可是我啥都不会···

感谢高手们···
2008-7-1 22:40
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.069793 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved