春晚刘谦第二个魔术原理讲解

2024-02-10 09:20

本文主要是介绍春晚刘谦第二个魔术原理讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1. 先说一下步骤:
  • 2. 原理讲解:
      • 2.1 第一步分析
      • 2.1 第二步分析
      • 2.1 第三步分析
      • 2.1 第四步分析
      • 2.1 第五步分析
      • 2.1 第六步分析
      • 2.1 第七步分析
      • 2.1 第八步分析
      • 2.1 第七步重新分析
  • 小结:

在这里插入图片描述

首先,先叠个甲。我本人很喜欢刘谦老师,初中的时候非常喜欢看刘谦老师的魔术,刘谦老师的魔术至今没有被解密的非常多,都是老师精心准备的。

这次春晚刘谦老师能上也是非常开心。想起以前看春晚,一看完刘谦老师的魔术,被吃惊到后,就急忙去看其他网友的激烈讨论。当然有的解密任然

第二个魔术并不难,是刘谦老师专门为观众准备的互动魔术,既然是面向全国观众的,观众自己上手的,原理呢自然观众是可以推理出来的。所以刘谦老师的设计必然是迎合观众的推理心理的,这个魔术是专门留给观众破解的。

1. 先说一下步骤:

第一步:拿四张牌、打乱,撕成两半,堆叠到一块
【牌数 = 8】

第二步:按名字字数依次把上面的放到下面

第三步:把上面的三张牌插入剩下的牌中间(只要中间就行)

第四步:最上面的一张牌拿出来,用于最后对比
【牌数 = 7】

第五步:如果是南方人,拿最上面1张;北方人2张;不清楚南北3张。放入剩余牌中间

第六步:男生扔掉最上面1张牌;女生扔掉最上面2张牌
【牌数 = 6 or 5】

第七步:“见证奇迹的时刻”,7次逐字,把最上面的牌放到最下面

第八步:“好运留下来,烦恼丢出去”,最上面的一个牌放到最下面,再扔一个。无限循环到剩下最后一个。这最后一个就是要找的能匹配到的牌。
【牌数 = 1】

2. 原理讲解:

我们逐步拆解:

2.1 第一步分析

我们不妨把第一步得到的结果列为如下(字母一样的表示为同一张牌,数字表示为分别两半):

A1
B1
C1
D1
A2
B2
C2
D2

2.1 第二步分析

先想一个问题:第二步真的起到作用了吗?当然是没有的。

为什么这么说呢,因为原本的第一步得到的排列顺序就是配对的两张牌间隔3张牌,也就是第二张牌在第一张牌的往下数第四号位。就算第二步执行了多少张牌,依旧是第二张牌在第一张牌的往下数第四号位。

比如移动3个:

D1
A2
B2
C2
D2
A1
B1
C1

毕竟名字的长度的区间可是[2, +∞)

所以,我们把字母变回ABCD的顺序,任然可以把结果表示为:

A1
B1
C1
D1
A2
B2
C2
D2

2.1 第三步分析

第三步是固定步骤,我们先把上面三张牌取下来,这时候魔术的目的就达成了,达成了什么呢?达成了D1在最上面,D2在最下面;至于上面三张牌插哪就无所谓了:

D1
A2
B2
C2
D2

2.1 第四步分析

最上面的一张牌拿出来,不如叫:最D1拿出来得了。

这时候我们反向思维,我们做完8步后最后剩下的牌一定是D2

2.1 第五步分析

所以,这里南北就不重要了,因为D2还是一定在最下面

2.1 第六步分析

这里也不重要了,因为D2还是一定在最下面

2.1 第七步分析

第七步和第八步是连起来的,我们先分析第八步

2.1 第八步分析

我们要保持我们的牌是个环形排序结构的思维,所以移动不移动都一样:
第八步简化后就等于:留一个扔一个到最后一个

这里还剩下 6 or 5 张牌是吧,我们模拟一下过程,一步一步得到最终结果:

6张牌

牌1
牌2
牌3
牌4
牌5
牌6

留一删一,这里牌1被留下,牌2被删除

牌1
牌2
牌3
牌4
牌5
牌6

以此类推,下面是一步一步得到最终结果:

牌1
牌2
牌3
牌4
牌5
牌6

牌1
牌2
牌3
牌4
牌5
牌6

牌1
牌2
牌3
牌4
牌5
牌6

牌1
牌2
牌3
牌4
牌5
牌6

5张牌

牌1
牌2
牌3
牌4
牌5

牌1
牌2
牌3
牌4
牌5

牌1
牌2
牌3
牌4
牌5

牌1
牌2
牌3
牌4
牌5

2.1 第七步重新分析

我们整理两种情况得到的最终结果:
6张牌

牌1
牌2
牌3
牌4
牌5
牌6

5张牌

牌1
牌2
牌3
牌4
牌5

所以,这里 6张牌情况中的牌5 = D25张牌情况中的牌3 = D2 。因为我们知道在第六步最后D2是在最底下,所以,我们倒回去把最下面的牌放到最上面7次后,6张牌情况中的牌55张牌情况中的牌3 都会回到最下面!!!

小结:

关注我给大家分享更多有趣的知识,以下是个人公众号,提供 ||代码兼职|| ||代码问题求解||
由于本号流量还不足以发表推广,搜我的公众号即可:
在这里插入图片描述

这篇关于春晚刘谦第二个魔术原理讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/696730

相关文章

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente

MySQL的隐式锁(Implicit Lock)原理实现

《MySQL的隐式锁(ImplicitLock)原理实现》MySQL的InnoDB存储引擎中隐式锁是一种自动管理的锁,用于保证事务在行级别操作时的数据一致性和安全性,本文主要介绍了MySQL的隐式锁... 目录1. 背景:什么是隐式锁?2. 隐式锁的工作原理3. 隐式锁的类型4. 隐式锁的实现与源代码分析4

MySQL中Next-Key Lock底层原理实现

《MySQL中Next-KeyLock底层原理实现》Next-KeyLock是MySQLInnoDB存储引擎中的一种锁机制,结合记录锁和间隙锁,用于高效并发控制并避免幻读,本文主要介绍了MySQL中... 目录一、Next-Key Lock 的定义与作用二、底层原理三、源代码解析四、总结Next-Key L

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr