前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据结构--链表--约瑟夫问题

数据结构--链表--约瑟夫问题

作者头像
Wu_Candy
发布2022-07-04 20:09:18
1700
发布2022-07-04 20:09:18
举报
文章被收录于专栏:无量测试之道
作者 | 无量测试之道 编辑 | 小 晴
这是无量测试之道的第157篇原创

1、今日主题

  今天的主题是使用循环链表来完成约瑟夫问题的求解。那么首先让我们先了解下,什么是约瑟夫问题。   据说著名犹太历史学家Josephus有过以下的故事:在罗马人占领乔塔帕特后,39 个犹太人与Josephus及他的朋友躲到一个洞中,39个犹太人决定宁愿死也不要被敌人抓到,于是决定了一个自杀方式,41个人排成一个圆圈,由第1个人开始报数,每报数到第3人该人就必须自杀,然后再由下一个重新报数,直到所有人都自杀身亡为止。然而Josephus 和他的朋友并不想遵从。首先从一个人开始,越过k-2个人(因为第一个人已经被越过),并杀掉第k个人。接着,再越过k-1个人,并杀掉第k个人。这个过程沿着圆圈一直进行,直到最终只剩下一个人留下,这个人就可以继续活着。问题是,给定了和,一开始要站在什么地方才能避免被处决。Josephus要他的朋友先假装遵从,他将朋友与自己安排在第16个与第31个位置,于是逃过了这场死亡游戏。下图是约瑟夫问题的图例。

2、问题分析


  我们将数据规模调小一点,假定数据规模为8,[1,2,3,4,5,6,7,8]。按照约瑟夫的算法:(ps:其中current指的是出局后重新开始的位置)

出局

链表调整

current指向

3

[1,2,4,5,6,7,8]

4

6

[1,2,4,5,7,8]

7

1

[2,4,5,7,8]

2

5

[2,4,7,8]

7

2

[4,7,8]

4

8

[4,7]

4

  1. 第一个出局的是3号,[1,2,4,5,6,7,8],current指向4
  2. 第二个出局的是6号,[1,2,4,5,7,8],current指向7
  3. 第二个出局的是1号,[2,4,5,7,8],current指向2
  4. 第二个出局的是5号,[2,4,7,8],current指向7
  5. 第二个出局的是2号,[4,7,8], current指向4
  6. 第二个出局的是8号,[4,7],current指向4
  7. 最后剩下[4,7] 这个数据模型就是循环链表,为了便于大家理解,我做了一张图:

3号出局后,如下图所示:

3、编码实现


  本文使用的编码语言为swift,读者朋友们可以有自己熟悉的语言来进行编码实现。重要的是理解原理和解题思路。我想你们肯定是懂得这个道理的。

  编码思路:

current走2步,然后删掉该结点,最后将current指向下一个结点。

循环第一步,直到链表为空

代码语言:javascript
复制

    let list = CircleList<Int>()
    for index in 1..<9 {
        list.add(index)//构造约瑟夫数据
    }
    while !list.isEmpty() {
    //走两步-->删结点-->继续执行 
        list.next()
        list.next()
        print( list.remove())
    }
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-11-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 无量测试之道 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、今日主题
    • 2、问题分析
      • 3、编码实现
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档