循环链表(空表为只有一个空节点的表,其link指针指向自身)很容易模拟一个环,其数据域可以用来储存编号,加上链表的删除操作,可以很简单的解决约瑟夫问题。 循环链表的实现以及约瑟夫问题的解决代码如下: CircLinkedList.h:该头文件定义了一些需要实现的循环链表的基本函数以及Josephus函数: 1/*Author:catcher qyjiang24@...
约瑟夫问题: 意思是===》 有n个人 ,手拉着手,围成一个圆圈,说 :“ 我们每m个数,在那个位置的人就必须自杀,接着往下数,自杀 。”一直循环下去。 比如有 10 人 ,规定 数到 2 就 去自杀。 1 2 3 4 5 6 7 8 9 第一次 ;往下数 2位 :123 4 5 6 7 8 9 ---2被刀了 第二次: 接着往下...
约瑟夫问题并不难,但求解的方法很多;题目的变化形式也很多。这里给出一种实现方法。 题目中30个人围成一圈,因而启发我们用一个循环的链来表示。可以使用结构数组来构成一个循环链。结构中有两个成员,其一为指向下一个人的指针,以构成环形的链;其二为该人是否被扔下海的标记,为1表示还在船上。从第一个人开始对...
约瑟夫环问题,是一个经典的循环链表问题,题意是:已知 n 个人(以编号1,2,3,…,n分别表示)围坐在一张圆桌周围,从编号为 k 的人开始顺时针报数,数到 m 的那个人出列;他的下一个人又从 1 还是顺时针开始报数,数到 m 的那个人又出列;依次重复下去,要求找到最后出列的那个人。 例如有 5 个人,要求从编...
一、创建一个循环链表 1.1创建一个结点 这个结点有两个属性: 一个是存储数字data 一个是存储下一个结点的地址 1.2通过这个结点创建一个循环链表 它需要具备以下几个功能: 增加、删除、打印 二、利用这个循环...循环链表解决约瑟夫问题 不多说了 直接贴代码了。 生成循环列表的方式有点儿恶心... ... 循环...
1.首先我们用Cycle_listinitList_Sq()函数建立一个最简单的循环链表。(Cycle_list 这个是我命名的结构体指针,应该很好懂的啦。)这里我巧妙的把头结点 head->date=1; 为什么呢?我后面解答。 Cycle_listinitList_Sq(){Cycle_list head;head=(Cycle_list)malloc(sizeof(LNode));head->next=head;head->date...
约瑟夫问题: 意思是===》 有n个人 ,手拉着手,围成一个圆圈,说 :“ 我们每m个数,在那个位置的人就必须自杀,接着往下数,自杀 。”一直循环下去。 比如有 10 人 ,规定 数到 2 就 去自杀。 1 2 3 4 5 6 7 8 9 第一次 ;往下数 2位 :123 4 5 6 7 8 9 ---2被刀了 第...