C语言单向循环链表解决约瑟夫问题
解决方案:
/*************************************************************************
> File Name: josefu.c
> Author: Baniel Gao
> Mail: createchance@163.com
> Blog: blog.csdn.net/createchance
> Created Time: Thu 19 Dec 2013 03:08:21 PM CST
************************************************************************/
#include <stdio.h>
#include <stdlib.h> typedef struct josefu
{
int data;
struct josefu *next;
} josefu_list; josefu_list *josefu_init(int num);
josefu_list *josefu_begin(josefu_list *list, int rule);
josefu_list *josefu_node(int num);
int josefu_free(josefu_list *list); int main(void)
{
josefu_list *list;
int num, rule; puts("Please input number and rules: ");
scanf("%d%d", &num, &rule);
list = josefu_init(num);
list = josefu_begin(list, rule); josefu_free(list); return 0;
} josefu_list *josefu_init(int num)
{
int i;
josefu_list *new;
josefu_list *list = josefu_node(1); for(i = num; i > 1; i--) {
new = josefu_node(i);
new->next = list->next;
list->next = new;
} return list;
} josefu_list *josefu_node(int num)
{
josefu_list *p = NULL; p = (josefu_list *)malloc(sizeof(josefu_list));
p->data = num;
p->next = p; return p;
} josefu_list *josefu_begin(josefu_list *list, int rule)
{
int counter;
josefu_list *tmp = NULL; for(counter = 1; list->next != list; counter++) {
if(counter == rule - 1) {
tmp = list->next;
list->next = tmp->next;
free(tmp);
counter = 0;
josefu_show(list);
}
list = list->next;
} return list;
} int josefu_show(josefu_list *list)
{
josefu_list *p = list; if(list == NULL)
return 0; do {
printf("%5d",p->data);
p = p->next;
} while(list != p);
putchar('\n');
} int josefu_free(josefu_list *list)
{
free(list); return 0;
}
运行实例:
C语言单向循环链表解决约瑟夫问题的更多相关文章
- C++循环链表解决约瑟夫环问题
		约瑟夫环问题可以简单的使用数组的方式实现,但是现在我使用循环链表的方法来实现,因为上午看到一道面试题规定使用循环链表解决约瑟夫环问题. 什么是约瑟夫环? “约瑟夫环是一个数学的应用问题:已知n个人(以 ... 
- 关于单向循环链表的约瑟夫问题(Java实现)
		关于单向循环链表的约瑟夫问题(Java实现) 最近在学习链表时,遇到单向循环链表中的约瑟夫问题.在构建循环链表的代码上,我有一点很不理解,遂记录下来. Josephu问题为: 设编号为1, 2,.. ... 
- 使用java的循环单向链表解决约瑟夫问题
		什么是约瑟夫问题 据说著名犹太历史学家 Josephus有过以下的故事:在罗马人占领乔塔帕特后,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定 ... 
- Java 用单向循环链表实现 约瑟夫问题
		public class lianbiao2 { class Node{ Node next; int number; public Node getNext() { return next; } p ... 
- golang数据结构之用循环链表解决约瑟夫环问题
		josephu.go package link import ( "fmt" ) type Kid struct { ID int next *Kid } func AddKid( ... 
- 基于visual Studio2013解决算法导论之021单向循环链表
		 题目 单向循环链表的操作 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <time.h> ... 
- C语言解决约瑟夫问题详解的代码
		将开发过程中比较重要的一些内容做个收藏,下面的内容是关于C语言解决约瑟夫问题详解的内容,希望能对码农有帮助. #pragma once #include<vector> class PRO ... 
- 单向循环链表C语言实现
		我们都知道,单向链表最后指向为NULL,也就是为空,那单向循环链表就是不指向为NULL了,指向头节点,所以下面这个程序运行结果就是,你将会看到遍历链表的时候就是一个死循环,因为它不指向为NULL,也是 ... 
- c语言实现--单向循环链表操作
		1,什么叫单向循环链表.单向循环链表是指在单链表的基础上,表的最后一个元素指向链表头结点,不再是为空. 2,由图可知,单向循环链表的判断条件不再是表为空了,而变成了是否到表头. 3,链表的结点表示 1 ... 
随机推荐
- LA 4119 (差分数列 多项式) Always an integer
			题意: 给出一个形如(P)/D的多项式,其中P是n的整系数多项式,D为整数. 问是否对于所有的正整数n,该多项式的值都是整数. 分析: 可以用数学归纳法证明,若P(n)是k次多项式,则P(n+1) - ... 
- codeforces 340A The Wall(简单数学题)
			题意:输入a,b,x,y,a,b分别是两人的步数(每a块砖,刷一次),则有一些砖被两人同时刷到了,问[x,y]区间内有多少块砖同时被两人刷到. 分析:就是求[x,y]中有多少个能把a,b的最小公倍数l ... 
- git - 搭建git仓库
			1. 更新git版本: http://codelife.me/blog/2013/06/25/upgrade-git-on-centos-6-4/ 2. 建立git仓库: git init --bar ... 
- AngularJS:实现动态添加输入控件功能(转)
			http://www.cnblogs.com/ilovewindy/p/3849428.html <!DOCTYPE html> <html> <head> < ... 
- ubuntu鼠标突然不能使用的解决方法
			今天发现鼠标(usb即插即用)不能用了,最后发现需要接通充电才可以!!!用电池的时候居然不可以用鼠标? 
- MyBatis 如何接收参数
			MyBatis的mapper接口不需要自己实现,框架会自动帮我们实现,到时候直接调用就可以了.定义的mapper接口中的方法可以有多个参数吗?答案是肯定.在Ibatis时代是自己通过代码实现如何调用x ... 
- 自己动手写路由器之ioctl获取网络接口信息
			最近打算写一个简单路由器,里面有用到ioctl获取网络接口信息,那就先把这部分单独拿出来说一说吧! ioctl这个函数,可以用来对特殊文件的基础设备参数进行操作,它们可以完成与打开文件描述符相关联的控 ... 
- HDU 4630-No Pain No Game(线段树+离线处理)
			题意: 给你n个数的序列a,q个询问,每个询问给l,r,求在下标i在[l,r]的区间任意两个数的最大公约数中的最大值 分析: 有了hdu3333经验,我们从左向右扫序列,如果当前数的约数在前面出现过, ... 
- NEUOJ711  异星工厂 字典树+贪心
			题意:你可以收集两个不相交区间的权值,区间权值是区间异或,问这两个权值和最大是多少 分析:很多有关异或求最大的题都是利用01字典树进行贪心,做这个题的时候我都忘了...最后是看别人代码的时候才想起来这 ... 
- java Ant 的使用
			Apache Ant 1.7.0 is the best available version的下载地址:http://ant.apache.org/bindownload.cgi 部署: 参考JAVA ... 
