2024春晚刘谦撕纸牌魔术背后的算法分析

这个魔术看了N遍,直观感觉是循环队列,通过一开始放牌的过程可以感受出来,代码通过循环链表实现更为简单。

本魔术的详细步骤:

准备工作

  1. 将四张牌对折后撕开,两堆顺序相同,均为2567。
  2. 同一方向堆在一起,相当于25672567。

第一部分

  1. 根据名字从顶部往底部拿牌。
  2. 将顶部三张插入剩余扑克牌中间位置,不可以放到末尾(即最后一张牌之后)。
  3. 拿起顶部第一张牌,放好。
  4. 自己是南方人拿起一张,北方人拿起两张,不确定南北方则拿起三张,均插入牌的中间位置。

第二部分

  1. 男生从上面拿起一张,女生从上面拿起两张,扔掉。
  2. 见证奇迹的时刻,7个字,自顶部移动到牌尾7次。
  3. 好运留下来,烦恼丢出去:顶部移至末尾,丢出顶部,重复迭代。
  4. 男生再迭代一次。

循环队列分步详解

准备工作

第一部分

组成循环队列

根据名字从顶部往底部拿牌,确立队首

把顶部三张牌插入中间,首尾相同

只要是中间位置即可

拿出第一张牌即当前队首,新队列,原位置置空

南北方人将顶部一至三张牌移至底部

第二部分

男生从上面拿起一张,女生从上面拿起两张,扔掉,置空为N。

见证奇迹的时刻,移动7次指针

好运留下来,烦恼丢出去:顶部移至末尾,丢出顶部,重复迭代

1 2

3

4

男生剩余两张,女生剩余一张,男生再次迭代

至此结束。

4张牌,撕开变八张,按名字字数移动,循环队列顺序并没有变,虚操作。

起初相同两张之间隔着3张牌,将三张插入中间之后,有两张相同的牌变为相邻的,拿出其中一张,剩余7张。

南北方人移动的操作并不会影响最后一张(即队尾)的牌,虚操作。

男女生这里真正开始迭代。

男生扔一张,剩余6张;女生扔两张,剩余5张。

见证奇迹的时刻为7个字,7除以6余1,7除以5余2,相当于分别向前移动了1位和2位,现在移动7个位置是为了同时移动偶数位。

剩下的步骤本质参考:约瑟夫环经典数学、计算机问题。

相关推荐
Old Uncle Tom2 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆2 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移2 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业2 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业4 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5485 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove5 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊6 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf7 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃7 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划