转载请注明出处:点我

昨天参加了企鹅的2015年实习生招聘的笔试,编程题第一道题就是约瑟夫圆环问题,要求用C++来实现。

约瑟夫圆环问题其实是一个很有名的问题:问题的描述为:

设有编号为1,2,……,n的n(n>0)个人围成一个圈,从第k个人开始报数,报到m时停止报数,报m的人出圈,再从他的下一个人起重新报数,报到m时停止报数,报m的出圈,……,如此下去,直到所有人全部出圈为止。当任意给定n和m后,设计算法求n个人出圈的次序。

这个问题网上的解法很多,我的思路是这样的:

所有人排成一排,每次由站在(最左边)排头的人报数(如果不是由站在排头的人报数,比如由站在第n位的人报数,则把前面n-1个人按照次序放到队伍的最后面),如果站在排头的人不符合出圈的要求,就把排头的人出队列,并站到排尾,队列全部往前移动一个位置。再由排头的人报数,以此类推。

这里以7个人为例,从第3个人开始报数,报到3的出队列,下一个接着报,以count表示当前的报数:

以7个人为例,每个人的编号依次为1,2,...7,把7个人依次放在一个队列里面,如下图所示:

因为是从第三个人开始报数,所以要把第三个人前面的两个人按照先后次序放到排尾,结果如下图所示:

此时,序号为3的人位于排头,由他开始报数,报数count = 1,不符合出队列要求,所以把他出队列,牌都排尾,然后队伍整体向前移动一个位置,如下图所示:

此时由位于排头的序号为4的人进行报数,count = 2,也不符合要求,同样的出队列,放到排尾,

此时序号为5的人站在排头,报数count=3,符合要求,现在把序号为5的人出队列,并输出序号

此时第一轮报数完成,序号为5的人出队列,输出5,设置count=0,并开始下一轮报数

现在序号6位于排头,报数count=1,不符合要求,出队列,站在排尾

重复上面的过程,即可得到出队列的次序为:

5 1 4 2 6 3 7

下面是代码实现:

 /*
* number个人围城一圈,从第start个人开始报数,
* 报到第k个数的人圈,下一个接着从头开始报数
* author:rio_2607
*/
void yuesefu(int number,int start,int k)
{
deque<int> queue;
//把number个人依次放入一个deque队列中去
for(int i = ;i <= number;++i)
queue.push_back(i);
int count = ;
while(count < start)
{
//只要还没有达到第start个人,就依次把最前面的元素放到最后面去
queue.push_back(queue.front());
queue.pop_front();
++count;
}
while(queue.size() != )
{
int step = ;
while(step < k)
{
//只要还没有报数报到第k个就把当前的元素放到queue的最后面去
queue.push_back(queue.front());
queue.pop_front();
++step;
} //数到了第k个,把第k个删除
cout << queue.front() << " ";
queue.pop_front();
}
}

因为要频繁的在队列的头部和尾部插入数据,删除数据,所以选择用STL中的deque容器来实现。

下面是测试程序:7个人,从第三个人开始报数,报道3的人出队列:

 int main()
{
int start = ,step = ;
int number = ;
yuesefu(number,start,step);
return ;
}

得到的输出结果是:

约瑟夫圆环的C++实现的更多相关文章

  1. 51nod 1074 约瑟夫环 V2

    N个人坐成一个圆环(编号为1 - N),从第1个人开始报数,数到K的人出列,后面的人重新从1开始报数.问最后剩下的人的编号. 例如:N = 3,K = 2.2号先出列,然后是1号,最后剩下的是3号. ...

  2. css3圆环百分比,菜单栏定位导航

    前段时间,社区个人中心改版,看了下设计图,当时隐约感觉到有两个地方(圆环百分比,菜单栏定位导航)比较麻烦.设计图大致如下: 首先看圆环百分比,网上的做法大致分两种,一种是用了CSS3中的transfo ...

  3. Android自定义View之圆环交替 等待效果

    学习了前面两篇的知识,对于本篇实现的效果,相信大家都不会感觉太困难,我要实现的效果是什么样呢?下面请先看效果图: 看上去是不很炫的样子,它的实现上也不是很复杂,重点在与onDraw()方法的绘制. 首 ...

  4. 约瑟夫问题(java实现)

    方法一.自定义的链表实现 package com.code.yuesefu; public class YueSeFuList { public static void main(String[] a ...

  5. Java 解决约瑟夫问题

    约瑟夫问题(有时也称为约瑟夫斯置换,是一个出现在计算机科学和数学中的问题.在计算机编程的算法中,类似问题又称为约瑟夫环.又称“丢手绢问题”.) 有这样一个故事,15个教徒和15个非教徒在深海遇险必须讲 ...

  6. 【BZOJ1662】[Usaco2006 Nov]Round Numbers 圆环数 数位DP

    [BZOJ1662][Usaco2006 Nov]Round Numbers 圆环数 Description 正如你所知,奶牛们没有手指以至于不能玩"石头剪刀布"来任意地决定例如谁 ...

  7. C#实现约瑟夫环问题

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace orde ...

  8. C语言数组实现约瑟夫环问题,以及对其进行时间复杂度分析

    尝试表达 本人试着去表达约瑟夫环问题:一群人围成一个圈,作这样的一个游戏,选定一个人作起点以及数数的方向,这个人先数1,到下一个人数2,直到数到游戏规则约定那个数的人,比如是3,数到3的那个人就离开这 ...

  9. C语言链表实现约瑟夫环问题

    需求表达:略 分析: 实现: #include<stdio.h> #include<stdlib.h> typedef struct node { int payload ; ...

随机推荐

  1. 基于opencv的手写数字识别(MFC,HOG,SVM)

    参考了秋风细雨的文章:http://blog.csdn.net/candyforever/article/details/8564746 花了点时间编写出了程序,先看看效果吧. 识别效果大概都能正确. ...

  2. 发现第三方资源,chrome控制台

    for(var i=0,tags=document.querySelectorAll('iframe[src],frame[src],script[src],link[rel=stylesheet], ...

  3. android LocalActivityManager说明

          类概述 Helper class for managing multiple running embedded activities in the same process. This c ...

  4. (转载)OC学习篇之---Foundation框架中的NSString对象和NSMutableString对象

    在之前的一篇文章中我们说到了Foundation框架中的NSObject对象,那么今天在在来继续看一下Foundation框架中的常用对象:NSString和NSMutableString. 在OC中 ...

  5. mysql error: Access denied for user 'root'@'localhost' (using password: YES)

    昨天重装了下系统,安装好mysql后,安装了客户端工具连接mysql,提示Access denied for user 'root'@'localhost' (using password: YES) ...

  6. hdu 1176 免费馅饼(数塔类型)

    http://acm.hdu.edu.cn/showproblem.php?pid=1176 免费馅饼 Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  7. Live m3u8播放3个文件自动停止问题

    Live m3u8播放3个文件自动停止问题 1.问题描述 最近做一个转码切片播放测试,使用HLS(HTTP Live Streaming)来做直播, 每个TS分片时间为10s,根据TS分片文件生成以下 ...

  8. easyui反选全选和全不选代码以及方法的使用

    首先要说明的是,onclick="javascript:这里能写方法的名字,也能写一段JS的代码,但是方法名字要带括号.",其次就是onclick=“这里写的方法名必须存在于本页面 ...

  9. 51Nod 1405 树的距离之和 (树dp)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1405 中文题面不解释了,两次dfs,第一次自下向上,第二次自上 ...

  10. POJ 3176 Cow Bowling (水题DP)

    题意:给定一个金字塔,第 i 行有 i 个数,从最上面走下来,只能相邻的层数,问你最大的和. 析:真是水题,学过DP的都会,就不说了. 代码如下: #include <cstdio> #i ...