按要求用C语言写约瑟夫环
答案:6 悬赏:20 手机版
解决时间 2021-03-10 13:46
- 提问者网友:雾里闻花香
- 2021-03-10 06:12
按要求用C语言写约瑟夫环
最佳答案
- 五星知识达人网友:woshuo
- 2021-03-10 07:41
这没啥高手的,人称入门题目,也就是说,会做这个基本就可以用C做一些东西了。这是我以前写的,从博客上面搞下来的,你试试看能不能运行,我当时似乎是运行过了的。不过这个不是用链表做的,用数组做的,你结合链表的语法把他改一下就行了,很简单的,就一个结构体而已么,反正基本思路这样就对了。另外对了,当时水平有限还不懂动态分配内存,你去查一下malloc函数的用法,觉得合适可以加进去,你用new命令也可以动态分配内存,具体的可以去看看MSDN,MSDN好东西啊。
#include
#include
void main()
{
int a[100];
int n,r,ctor,u;
int call(int a[],int real,int u);
for(n=0;n<=99;n++)a[n]=0;
printf("/约瑟夫环 JOSEPHUS/\n\n");
printf("输入参与报数的人数\n");
scanf("%d",&r);
printf("输入报数上限\n");
scanf("%d",&u);
ctor=1;
for(n=0;n {
*(a+n)=ctor;
ctor++;
if(ctor>u)ctor=1;
}
call(a,r,u);system("pause");
}
int call(int a[],int real,int u)
{
int n1,i;
int *p;
p=(a+u-1);
n1=0;i=u;
for(;n1 {
if(p>(a+real-1))p=a;
if(*(p)!=0)
{
if(i>u)i=1;
if(i==u)
{
*(p)=0;n1++;
}
i++;
}
}
for(i=0;i if(*(a+i)!=0)printf("所剩最后一位原来的呼号是%d\n\n",i+1);
}
写完了
#include
#include
void main()
{
int a[100];
int n,r,ctor,u;
int call(int a[],int real,int u);
for(n=0;n<=99;n++)a[n]=0;
printf("/约瑟夫环 JOSEPHUS/\n\n");
printf("输入参与报数的人数\n");
scanf("%d",&r);
printf("输入报数上限\n");
scanf("%d",&u);
ctor=1;
for(n=0;n
*(a+n)=ctor;
ctor++;
if(ctor>u)ctor=1;
}
call(a,r,u);system("pause");
}
int call(int a[],int real,int u)
{
int n1,i;
int *p;
p=(a+u-1);
n1=0;i=u;
for(;n1
if(p>(a+real-1))p=a;
if(*(p)!=0)
{
if(i>u)i=1;
if(i==u)
{
*(p)=0;n1++;
}
i++;
}
}
for(i=0;i
}
写完了
全部回答
- 1楼网友:未来江山和你
- 2021-03-10 14:19
做这个问题很麻烦,分太低了。
- 2楼网友:枭雄戏美人
- 2021-03-10 12:41
刚刚也有人问了,真是巧。我昨天自己还在做数据结构时候也碰到了。所以两个都给你吧
#include
#define N 13
struct person
{
int number;
int nextp;
}link[N+1];
void main()
{
int i,count,h;
for(i=0;i<=N;i++)
{
if(i==N)
link[i].nextp=1;
else
link[i].nextp=i+1;
link[i].number=i;
}
printf("\n");
count=0;
h=N;
printf("sequence that persons leave the circle:\n");
while (count {
i=0;
while(i!=3)
{
h=link[h].nextp;
if(link[h].number)
i++;
}
printf("%4d",link[h].number);
link[h].number=0;
count++;
}
printf("\nThe last one is");
for(i=1;i<=N;i++)
if(link[i].number)
printf("%3d",link[i].number);
printf("\n");
}
数据结构的思路:
void Josephus(int n,int m,int s)
//使用带表头附加节点的循环单链表为空
{
//生成表头附加结点,此时循环单链表为空
LNode* HL=new LNode;
HL->next=HL;
int i;
//生成含n个结点的,结点值依次为1-n的带表头附加结点的循环表
for(i=n;i>=1;i--)
//生成新结点
LNode* newptr=new LNode;
newptr->data=i;
//新结点插入到表头
newptr->next=HL->next;
HL->next=newptr;
}
//从表头开始顺序查找出第s个结点,对应第1个开始报数的人
LNode *ap=HL,*cp=HL->next;
for(i=1;i//ap和cp指针后移一个位置
ap=cp;
cp=cp->nextl
//若cp指向了表头附加的结点,则仍需后移指针,使之指向表头结点
if(cp==HL){ap=HL;cp=HL->next;}
}
//依次使n-1个人出列
for(i=1;i //顺序查找出待出列的人,即为循环结束后cp所指向的结点
for(int j=1;j {
ap=cp;
cp=cp->next;
if(cp==HL){ap=HL;cp=HL->next;}
}
//输出cp结点的值,即出列的人
cout<data<<" ";
//从单链表中删除结点的后继结点
cp=ap->next;
//若cp指向了表头附加结点,则后移ap和cp指针
if(cp==HL){ap=HL;cp=HL->next;}
}
//使最后一个人出列
cout<next->data< //删除表头结点和表头附加结点
delete HL->next;
delete HL;
}
#include
#define N 13
struct person
{
int number;
int nextp;
}link[N+1];
void main()
{
int i,count,h;
for(i=0;i<=N;i++)
{
if(i==N)
link[i].nextp=1;
else
link[i].nextp=i+1;
link[i].number=i;
}
printf("\n");
count=0;
h=N;
printf("sequence that persons leave the circle:\n");
while (count
i=0;
while(i!=3)
{
h=link[h].nextp;
if(link[h].number)
i++;
}
printf("%4d",link[h].number);
link[h].number=0;
count++;
}
printf("\nThe last one is");
for(i=1;i<=N;i++)
if(link[i].number)
printf("%3d",link[i].number);
printf("\n");
}
数据结构的思路:
void Josephus(int n,int m,int s)
//使用带表头附加节点的循环单链表为空
{
//生成表头附加结点,此时循环单链表为空
LNode* HL=new LNode;
HL->next=HL;
int i;
//生成含n个结点的,结点值依次为1-n的带表头附加结点的循环表
for(i=n;i>=1;i--)
//生成新结点
LNode* newptr=new LNode;
newptr->data=i;
//新结点插入到表头
newptr->next=HL->next;
HL->next=newptr;
}
//从表头开始顺序查找出第s个结点,对应第1个开始报数的人
LNode *ap=HL,*cp=HL->next;
for(i=1;i
ap=cp;
cp=cp->nextl
//若cp指向了表头附加的结点,则仍需后移指针,使之指向表头结点
if(cp==HL){ap=HL;cp=HL->next;}
}
//依次使n-1个人出列
for(i=1;i
for(int j=1;j
ap=cp;
cp=cp->next;
if(cp==HL){ap=HL;cp=HL->next;}
}
//输出cp结点的值,即出列的人
cout<
//从单链表中删除结点的后继结点
cp=ap->next;
//若cp指向了表头附加结点,则后移ap和cp指针
if(cp==HL){ap=HL;cp=HL->next;}
}
//使最后一个人出列
cout<
delete HL->next;
delete HL;
}
- 3楼网友:春色三分
- 2021-03-10 11:23
我用的双向循环链表写的 因为这样比较容易解决一些特殊情况
随机数的上线我设置的是小于起始时的人数 大了也没有什么意义 无非多转几圈 反而不好验证
以前就打算写这个程序 一直没时间
这段时间正好复习一下数据结构
顺便写一些这方面的程序
#include"stdio.h"
#include"windows.h"
#include"malloc.h"
#include"time.h"
#define N 10
typedef struct node
{
int num ;
int sec ;
struct node *pre;
struct node *next;
}body;
void Initiate(body *x);
void Delect(int x,body *head);
void main()
{
int m;
body *first;
first=(body *)malloc(sizeof(body));
first->next=first;
first->pre=first;
Initiate(first);
m=rand()%(N-1);
m=m+1;
printf("\n任意数m=%d\n",m);
Delect(m,first);
}
void Initiate(body *head)
{
int xx[N],yy[N];
int i;
body *p,*q;
for(i=0;i srand( time(NULL) );
for(i=0;i head->num=yy[0];
head->sec=xx[0];
for(i=1;i {
p=head;
q=(body *)malloc(sizeof(body));
q->num=yy[i];
q->sec=xx[i];
while(p->next!=head) p=p->next;
p->next=q;
q->pre=p;
q->next=head;
head->pre=q;
}
printf("序号:");
for(i=0;i printf("\n密码:");
for(i=0;i }
void Delect(int x,body *head)
{
body *p;
p=head;
int i=1,sec;
while(inext!=p) {p=p->next;i++;}
if(p->next!=p)
{
sec=p->sec;
printf("序号: %2d 密码: %2d \n",p->num,p->sec);
p=p->pre;
p->next=p->next->next;
p->next->pre=p;
head=p->next;
Delect(sec,head);
}
else
{
printf("序号: %2d 密码: %2d \n",p->num,p->sec);
printf("\n问题结束!\n");
}
}
随机数的上线我设置的是小于起始时的人数 大了也没有什么意义 无非多转几圈 反而不好验证
以前就打算写这个程序 一直没时间
这段时间正好复习一下数据结构
顺便写一些这方面的程序
#include"stdio.h"
#include"windows.h"
#include"malloc.h"
#include"time.h"
#define N 10
typedef struct node
{
int num ;
int sec ;
struct node *pre;
struct node *next;
}body;
void Initiate(body *x);
void Delect(int x,body *head);
void main()
{
int m;
body *first;
first=(body *)malloc(sizeof(body));
first->next=first;
first->pre=first;
Initiate(first);
m=rand()%(N-1);
m=m+1;
printf("\n任意数m=%d\n",m);
Delect(m,first);
}
void Initiate(body *head)
{
int xx[N],yy[N];
int i;
body *p,*q;
for(i=0;i
for(i=0;i
head->sec=xx[0];
for(i=1;i
p=head;
q=(body *)malloc(sizeof(body));
q->num=yy[i];
q->sec=xx[i];
while(p->next!=head) p=p->next;
p->next=q;
q->pre=p;
q->next=head;
head->pre=q;
}
printf("序号:");
for(i=0;i
for(i=0;i
void Delect(int x,body *head)
{
body *p;
p=head;
int i=1,sec;
while(i
if(p->next!=p)
{
sec=p->sec;
printf("序号: %2d 密码: %2d \n",p->num,p->sec);
p=p->pre;
p->next=p->next->next;
p->next->pre=p;
head=p->next;
Delect(sec,head);
}
else
{
printf("序号: %2d 密码: %2d \n",p->num,p->sec);
printf("\n问题结束!\n");
}
}
- 4楼网友:一叶十三刺
- 2021-03-10 09:47
我刚做啊!!!!!!!!!!
#include
#include
typedef struct node
{
int date;
int number;
struct node *next;
}ListNode;
ListNode *createlist(int n,int a[])
{
int j;
ListNode *head=(ListNode *)malloc(sizeof(ListNode));
ListNode *s,*r=head;
for(j=1;j<=n;j++)
{
s=(ListNode *)malloc(sizeof(ListNode));
s->date=a[j];
s->number=j;
r->next=s;
r=s;
}
r->next=head->next;
free(head);
return r;
}
void getnode(ListNode *head)
{
int m,k,i;
ListNode *p,*r;
p=head;
printf("输入上限值的初值 :");
scanf("%d",&m);
printf("出列顺序 :");
if(m>0)
{
while(p->next!=p)
{
for(k=1;k p=p->next;
printf("%d ",p->next->number);
m=p->next->date;
r=p->next;
p->next=r->next;
free(r);
}
printf("%d",p->number);
free(p);
printf("\n");
}
}
void main()
{
ListNode *ha;
int a[100],n,i;
printf("输入人数 :");
scanf("%d",&n);
printf("输入密码 :");
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
ha=createlist(n,a);
getnode(ha);
printf("\n");
}
#include
#include
typedef struct node
{
int date;
int number;
struct node *next;
}ListNode;
ListNode *createlist(int n,int a[])
{
int j;
ListNode *head=(ListNode *)malloc(sizeof(ListNode));
ListNode *s,*r=head;
for(j=1;j<=n;j++)
{
s=(ListNode *)malloc(sizeof(ListNode));
s->date=a[j];
s->number=j;
r->next=s;
r=s;
}
r->next=head->next;
free(head);
return r;
}
void getnode(ListNode *head)
{
int m,k,i;
ListNode *p,*r;
p=head;
printf("输入上限值的初值 :");
scanf("%d",&m);
printf("出列顺序 :");
if(m>0)
{
while(p->next!=p)
{
for(k=1;k
printf("%d ",p->next->number);
m=p->next->date;
r=p->next;
p->next=r->next;
free(r);
}
printf("%d",p->number);
free(p);
printf("\n");
}
}
void main()
{
ListNode *ha;
int a[100],n,i;
printf("输入人数 :");
scanf("%d",&n);
printf("输入密码 :");
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
ha=createlist(n,a);
getnode(ha);
printf("\n");
}
- 5楼网友:骨子里都是戏
- 2021-03-10 08:28
#include
#include
struct node
{
int num;//为方便表达,每个节点拥有一个序号
int password;//密码
struct node *next;
};
node * creatlist(int people)//构造链表
{
int i=1;//序号
int _password;
node *r,*s;
node *L=(node *)malloc(sizeof(node));//创造头结点
r=L;
while(i<=people)
{
printf("请输入第%d个人的密码:",i);
scanf("%d",&_password);
s=(node *)malloc(sizeof(node));
s->num=i;
s->password=_password;
r->next=s;
r=s;
i++;
}
r->next=L;//循环链表
return L;
}
void getoutseq(node *L,int firstp)//计算出列顺序并输出的函数
{
int _password=firstp;
node *p=L;
node *r=L;//r为p的前驱节点
int i=1;
while(L->next!=L)//当L为非空表时一直循环,空表表示所有人已经出列,则退出循环
{
while (i<=_password)//根据密码移动指针
{
if (p->next!=L)//当p的下一个节点非头结点,直接向下移
{
r=p;//p移动前先备份
p=p->next;
}
else//当p的下一个节点是头节点,则令p指向一号节点
{
r=L;
p=L->next;
}
i++;
}
printf("%d号出列\n",p->num);
_password=p->password;//获取节点中的密码
r->next=p->next;//删除并释放p
free(p);
i=1;
p=r;
}
printf("结束!\n");
}
int main()
{
node *list;
int people;
int firstp;
printf("请输入人数:");
scanf("%d",&people);
putchar('\n');
printf("请输入初始密码:");
scanf("%d",&firstp);
putchar('\n');
list=creatlist(people);
getoutseq(list,firstp);
printf("按确定键退出。。。");
getchar();
getchar();
return 0;
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯