【剑指offer】约瑟夫环问题
转载请注明出处:http://blog.csdn.net/ns_code/article/details/27957407
- 题目描写叙述:
-
每年六一儿童节,JOBDU都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。
HF作为JOBDU的资深元老,自然也准备了一些小游戏。当中,有个游戏是这种:首先,让小朋友们围成一个大圈。
然后,他随机指定一个数m,让编号为1的小朋友開始报数。每次喊到m的那个小朋友要出列唱首歌,然后能够在礼品箱中随意的挑选礼物,而且不再回到圈中,从他的下一个小朋友開始,继续1...m报数....这样下去....直到剩下最后一个小朋友,能够不用表演,而且拿到JOBDU名贵的“名侦探柯南”典藏版(名额有限哦!!^_^)。
请你试着想下,哪个小朋友会得到这份礼品呢?
- 输入:
-
输入有多组数据。
每组数据一行,包括2个整数n(0<=n<=1,000,000),m(1<=m<=1,000,000),n,m分别表示小朋友的人数(编号1....n-1,n)和HF指定的那个数m(如上文所述)。
假设n=0,则结束输入。
- 输出:
-
相应每组数据,输出最后拿到大奖的小朋友编号。
- 例子输入:
-
1 10
8 5
6 6
0
- 例子输出:
-
1
3
4
约瑟夫环问题。最简单直观的方法就是用数组或者链表模拟整个游戏的过程,我先是用数组模拟实现了下。
数组模拟实现的代码例如以下:
#include<stdio.h> typedef struct Node
{
int next; //下一个元素的编号
int num; //编号,从1開始
}Node; Node arr[1000000]; int FindLastRemaining(int n,int m)
{
if(n<1 || m<1)
return 0; int start = 1;
int current = start;
int pre = current;
while(start != arr[start].next)
{
//找到待删元素和它的前一个元素
int i;
for(i=0;i<m-1;i++)
{
pre = current;
current = arr[current].next;
} //删除元素,又一次建立连接
arr[pre].next = arr[current].next;
start = arr[pre].next;
current = start;
}
return arr[start].num;
} int main()
{
int n;
while(scanf("%d",&n) != EOF && n != 0)
{
int m;
scanf("%d",&m); //将数据连成环
int i;
for(i=1;i<=n;i++)
{
arr[i].num = i;
if(i == n)
arr[i].next = 1;
else
arr[i].next = i+1;
} printf("%d\n",FindLastRemaining(n,m));
}
return 0;
}
自己測试了几组数据,都对了,可是在九度OJ上測试,五个測试用例,仅仅通过两个,第二个測试用例WA。后面两个超时了。
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbW1jX21hb2R1bg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" />
超时就不说了,模拟实现的方法,时间复杂度为O(m*n)。数据非常大时时间消耗就上来了。可是第二个測试用例报了WA,左看右看还是不知道哪里出了问题,不想继续纠结下去了!看到这篇博文的有心者。有发现问题所在的话,提示下。
无奈这个思路的代码木有AC,即使结果正确,也会超时。仅仅能硬着头皮去研究下书上O(n)的做法,顺着书上面的思路。推了半个多小时。总算勉强搞定了,这种思路假设事先没个结论在胸中的话,面试现场基本是不可能推导出来的,除非曾经就知道并推导过这个数学公式。
关于思路。不说太多了。能够看剑指offer,上面写的还是蛮具体的,最好自己动手推推。这里重点说几点我的理解
1、个人感觉对推到时,最好不要用%来合并两个分段函数,最好p(x)依照x的范围分段,这样比較easy理解。这样p(x)有两段函数。求得的逆函数相同是分段函数。
2、k=(m-1)%n永远指的从0開始删除的第m个元素,也就是编号为m-1的元素。由于每次都会对元素的编号做映射,使每次从新開始报数的元素的编号都映射为从0開始。
3、书中通过找规律得到p(x)=(x-k-1)%n,这个感觉不严谨,由于x-k-有可能出现负的情况,应该写为p(x)=(n+x-k-1)%n。但终于求的的递推公式是一样的。由于这里不会出现超过2倍的情况。
另外,九度上的题目要求的编号是从1開始的,这简单。直接将结果的编号加1就可以。
AC代码:
#include<stdio.h> int LastRemaining(int n,int m)
{
if(n<1 || m<1)
return 0; int last = 0;
int i;
for(i=2;i<=n;i++)
last = (last + m)%i;
return last;
} int main()
{
int n;
while(scanf("%d",&n) != EOF && n != 0)
{
int m;
scanf("%d",&m);
printf("%d\n",LastRemaining(n,m)+1);
}
return 0;
}
/************************************************************** Problem: 1356 User: mmc_maodun Language: C Result: Accepted Time:290 ms Memory:912 kb****************************************************************/
【剑指offer】约瑟夫环问题的更多相关文章
- C++版 - 剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题,ZOJ 1088:System Overload类似)题解
剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题) 原书题目:0, 1, - , n-1 这n个数字排成一个圈圈,从数字0开始每次从圆圏里删除第m个数字.求出这个圈圈里剩下的最后一个数字 ...
- 剑指 Offer 62. 圆圈中最后剩下的数字 + 约瑟夫环问题
剑指 Offer 62. 圆圈中最后剩下的数字 Offer_62 题目描述 方法一:使用链表模拟 这种方法是暴力方法,时间复杂度为O(nm),在本题中数据量过大会超时. 方法二:递归方法 packag ...
- 面试题目——《剑指Offer》
1.把一个字符串转换成整数——<剑指Offer>P29 2.求链表中的倒数第k个结点——<剑指Offer>P30 3.实现Singleton模式——<剑指Offer> ...
- 【剑指Offer学习】【全部面试题汇总】
剑指Offer学习 剑指Offer这本书已经学习完了.从中也学习到了不少的东西,如今做一个总的文件夹.供自已和大家一起參考.学如逆水行舟.不进则退.仅仅有不断地学习才干跟上时候.跟得上技术的潮流! 全 ...
- 《剑指offer》全部题目-含Java实现
1.二维数组中的查找 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. publi ...
- 【剑指Offer学习】【所有面试题汇总】
剑指Offer学习 剑指Offer这本书已经学习完了,从中也学习到了不少的东西,现在做一个总的目录,供自已和大家一起参考,学如逆水行舟,不进则退.只有不断地学习才能跟上时候,跟得上技术的潮流! 所有代 ...
- 剑指offer题目java实现
Problem2:实现Singleton模式 题目描述:设计一个类,我们只能生成该类的一个实例 package Problem2; public class SingletonClass { /* * ...
- 剑指offer算法总结
剑指offer算法学习总结 节选剑指offer比较经典和巧妙的一些题目,以便复习使用.一部分题目给出了完整代码,一部分题目比较简单直接给出思路.但是不保证我说的思路都是正确的,个人对算法也不是特别在行 ...
- 剑指offer 面试62题
面试62题: 题目:圆圈中最后剩下的数字 题:0,1,...,n-1这n个数字排成一个圆圈,从数字0开始,每次从这个圆圈里删除第m个数字.求出这个圆圈里剩下的最后一个数字. 解题思路:约瑟夫环问题,可 ...
随机推荐
- 详解js和jquery里的this关键字
详解js和jquery里的this关键字 js中的this 我们要记住:this永远指向函数运行时所在的对象!而不是函数被创建时所在的对象.this对象是在运行时基于函数的执行环境绑定的,在全局环境中 ...
- qt学习笔记(七)之数据库简介(所有支持数据库类型的列表)
笔者最近用Qt写公司的考勤机.本来要求是要基于frameBuffer下用自己开发的easyGUI来进行上层应用开发,但是考虑到easyGUI提供的接口不是很多,就考虑用Qt来开发,顺带练练手. 废话不 ...
- twemproxy 简介
twemproxy,也叫nutcraker.是twtter开源的一个redis和memcache代理服务器. redis作为一个高效的缓存服务器,非常具有应用价值.但是当使用比较多的时候,就希望可以通 ...
- Hadoop2.0/YARN深入浅出(Hadoop2.0、Spark、Storm和Tez)
随着云计算.大数据迅速发展,亟需用hadoop解决大数据量高并发访问的瓶颈.谷歌.淘宝.百度.京东等底层都应用hadoop.越来越多的企 业急需引入hadoop技术人才.由于掌握Hadoop技术的开发 ...
- SRM 582 Div II Level Three: ColorTheCells, Brute Force 算法
题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=12581 Burte Force 算法,求解了所有了情况,注意 ...
- css3圆角代码
div+css3普通圆角代码示例 <style type="text/css"> #round { width:200px; height:100px; margin: ...
- Windows 8 动手实验系列教程 实验6:设置和首选项
动手实验 实验6:设置和首选项 2012年9月 简介 实验3介绍了合约并演示了应用程序如何轻松地与共享和搜索合约实现集成.合约同样包含设置超级按钮,它对活动的Windows应用商店应用的设置进行修改. ...
- Node-Webkit作者王文睿:桌面应用的全新开发方式
摘要:最近两年,Node.js技术越来越火,基于它所开发的应用也纷纷出现在大家面前,其中Node-Webkit就是这样的一个开源框架,它允许开发者使用Web技术开发桌面应用. Node-Webkit是 ...
- 移动App-UI配制篇
杂志app-UI配制篇 背景 现在公司有需求是关于杂志app,里面每个页面可能有不同的展现方式,不同的内容,不同的操作方式.那么这里就有一个需求就是根据用户定制这些不同的展现方式,不同的内容,不同的操 ...
- 图解UML类与类之间的六中关系
大话设计模式上的一个图,我用EA画出来的: UML中的6大关系相关英文及音标: 依赖关系 dependency [di'pendənsi] 关联关系 association [ə,səuʃi' ...