约瑟夫算法

//约瑟夫单循环算法
#include"stdio.h"
#include"stdlib.h"


typedef struct Point
{
 int Data;//数据域
 struct Point * Next;//指针域
}LNode,*LinkList;


int n,m;//n代表总人数,m代表出列的人序号

//创建单循环链表并返回
LinkList Create()
{
   int i;
   LinkList head,tail,NewNode;//创建三个节点
   head = NULL;
   printf("请输入总人数:\n");
   scanf("%d",&n);
   printf("请输入将要出列人的序号:\n");
   scanf("%d",&m);
   for(i = 1;i <= n;i++)
   {
    NewNode = (LinkList) malloc (sizeof(LNode));
    NewNode ->Data = i;
    if(head == NULL)//插入链表的第一个节点
    {
     head = NewNode;
     tail = NewNode;
    }
    else
    {
     tail ->Next = NewNode;
     tail = NewNode;
    }

   }
   tail ->Next = head;
   return head;

}


//用单向链表实现报数问题
void Search(LinkList head)
{
 int count,num;
 LinkList pre,p;
 num = 0;
 count = 1;
 p = head;
 printf("输出处理后的序列:\n");
 while(num < n)
 {//累计报数
  do
  {
   count++;
   pre = p;
   p = p->Next;
  }while(count < m);
        pre ->Next = p ->Next;//报m的人出列
  printf("%3d",p->Data);
  
  free(p);
  p = pre ->Next;
  count = 1;
  num++;
 }
 printf("\n");
}


main()
{
 LinkList head;
 head = Create();
 Search(head);
}

/*
2012年11月3日10:58:38
输出结果:
请输入总人数:
8
请输入将要出列人的序号:
2
输出处理后的序列:
 2  4  6  8  3  7  5  1

*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值