约瑟夫环(约瑟夫问题)求最后出列的人数

栏目: 编程工具 · 发布时间: 6年前

内容简介:约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。如5个人,从编号为1的人开始报数,数到3的人出列,最后出列的人的编号为4。编写一个函数,总人数为50,从编号为1的人开始报数,数到3的人出列,计算出最后出列的人的编号。

约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。如5个人,从编号为1的人开始报数,数到3的人出列,最后出列的人的编号为4。

编写一个函数,总人数为50,从编号为1的人开始报数,数到3的人出列,计算出最后出列的人的编号。

NSUInteger printLastDequeuedNumberInRoundTable(NSUInteger allMembersCount, NSUInteger dequeueNumber) {
    NSMutableDictionary<NSNumber *, NSString *> *dictM = @{}.mutableCopy;
    NSUInteger startIdx = 1;//first idx is 1 in round table issue
    //all members always dequeued finally
    while (dictM.allKeys.count != allMembersCount) {
        //members always sing from `1..dequeueNumber`
        for (NSUInteger i = 1; i <= dequeueNumber; i++) {
            //member at startIdx dequeued
            if (dictM[@(startIdx)]) {
                //ignore this, step next
                i--;
            } else {
                if (i == dequeueNumber) {
                    //record every `round table number` when last member who sing `dequeueNumber`
                    dictM[@(startIdx)] = @"dequeued";
                    if (dictM.allKeys.count == allMembersCount) {
                        NSUInteger lastNum = (startIdx - 1)%allMembersCount + 1;
                        NSLog(@"last member at number %ld dequeued", lastNum);
                        return lastNum;
                    } else {
                        NSLog(@"member at number %ld dequeued", (startIdx - 1)%allMembersCount + 1);
                    }
                }
            }
            ++startIdx;
            //the index in round table member varied from 1 to allMembersCount
            startIdx = (startIdx - 1)%allMembersCount + 1;
        }
    }
    return NSNotFound;
}
复制代码
NSUInteger lastNumber = printLastDequeuedNumberInRoundTable(50, 3);
lastNumber = 11;
复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JSP信息系统开发实例精选

JSP信息系统开发实例精选

赛奎春 / 机械工业出版社 / 2006-1 / 44.00元

本书精选了大学生就业求职网、物流短信平台、化奥汽车销售集团网站、佳美网络购物中心、科研成果申报管理系统、安瑞奥国际商务不院招生网、明日宽带影院、雄霸天下游戏网等8个综合的网络信息系统工程作为案例,深入剖析了实际的网络信息系统的开发思路、方法和技巧。帮助读者透彻掌握JSP开发网络信息系统的方法和步骤,从而设计出具有实用价值和商用价值的信息系统。   本书产例具有很强的实用性和工程实践性,在讲解......一起来看看 《JSP信息系统开发实例精选》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

随机密码生成器
随机密码生成器

多种字符组合密码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具