当前位置: 首页 > news >正文

【C/C++】2024春晚刘谦春晚魔术步骤模拟+暴力破解

 

        在这个特别的除夕夜,我们不仅享受了与家人的温馨团聚,还被电视机前的春节联欢晚会深深吸引。特别是,魔术师刘谦的精彩表演,为我们带来了一场视觉和心灵的盛宴。在我的博客“【C/C++】2024春晚刘谦春晚魔术步骤模拟+暴力破解”中,我将带领大家一探究竟,用编程的角度去解析刘谦的扑克牌魔术。

        刘谦的魔术不仅仅是技巧的展示,更是智慧和创意的结晶。他的表演激发了我们的好奇心,让无数观众纷纷拿起家中的扑克牌,尝试跟随他的步伐,去“见证奇迹”。在这篇博客中,我们将使用C/C++语言,尝试模拟魔术的每一个步骤,并探索可能的破解方法。通过编程的途径,我们不仅能深入理解魔术背后的逻辑,也能增强我们解决问题的能力。

        无论你是编程爱好者,还是魔术的忠实粉丝,我相信这篇博客都能为你带来全新的视角和体验。让我们一起揭开刘谦魔术的神秘面纱,探索那些看似不可能,却被巧妙设计和精湛技艺变为可能的奇迹吧。

目录

魔 术 步 骤 

步骤 1

步骤 2

步骤 3

步骤 4

步骤 5

步骤 6

步骤 7

代码如下

运行结果

结语


魔 术 步 骤 

首先,准备4张扑克牌,跟随魔术步骤,来一起“见证奇迹”。

步骤 1
  • 将准备好的4张扑克牌
  • 平均撕成两份
  • 并叠在一起
步骤 2
  • 将牌堆顶数量为
  • 【名字字数】的牌
  • 移至牌堆底
步骤 3
  • 将前三张牌放在牌堆中间
  • 并取出牌堆顶的牌
  • 放置在一旁
步骤 4
  • 取出牌堆顶的若干张牌
  • 插入牌堆中间
  • 此处选择的牌数为
  • 南方人取1张,北方人取2张
  • 若不确定是南方人还是北方人取3张
步骤 5
  • 男生扔掉牌堆顶1张
  • 女生扔掉牌堆顶2张
步骤 6
  • 执行“见证奇迹的时刻”循环
  • 每说一个字
  • 就取出牌堆顶一张牌放置在牌堆底
步骤 7

👇执行如下操作👇

  • 从牌堆顶开始
  • 每次先将牌堆顶的一张牌放在牌堆底
  • 再扔掉牌堆顶的一张牌
  • 重复以上操作直到只剩一张牌
  • 检查此牌和放置在一旁的牌是否吻合
  • 若吻合,则魔术成功

按照上面的魔术步骤用C/C++进行模拟和暴力破解

代码如下

#include <iostream>
#include <vector>
#include <algorithm> using namespace std;struct Card {int value; // 用数字代表扑克牌,简化处理
};// 打印牌堆
void printDeck(const vector<Card>& deck) {for (auto& card : deck) {cout << card.value << " ";}cout << endl;
}// 步骤 2: 根据给定的名字字数移动牌
void moveCardsForName(vector<Card>& deck, int nameLength) {rotate(deck.begin(), deck.begin() + nameLength, deck.end());
}// 步骤 3: 取出牌堆顶的牌并放置在一旁
Card takeTopCard(vector<Card>& deck) {Card topCard = deck.front();deck.erase(deck.begin()); // 移除顶部牌return topCard;
}// 步骤 4: 根据地域移动牌
void moveCardsByRegion(vector<Card>& deck, int cardsToMove) {// 假设“地域”只影响移动的牌数rotate(deck.begin(), deck.begin() + cardsToMove, deck.end());
}// 步骤 5: 根据性别移除牌
void removeCardsByGender(vector<Card>& deck, char gender) {int removeCount = (gender == 'M') ? 1 : 2;deck.erase(deck.begin(), deck.begin() + removeCount);
}// 步骤 6: 循环移动牌
void cycleCards(vector<Card>& deck, const string& phrase) {for (size_t i = 0; i < phrase.length(); ++i) {Card card = deck.front();deck.erase(deck.begin());deck.push_back(card); // 将顶部牌移动到底部}
}// 步骤 7: 执行最终操作,直到只剩一张牌,然后比较
bool finalOperationAndCompare(vector<Card>& deck, const Card& asideCard) {while (deck.size() > 1) {cout << "弃牌之前手里卡牌为: ";printDeck(deck);deck.push_back(deck.front()); // 将顶部牌移动到底部cout << "将顶部卡牌移至底部: ";printDeck(deck);deck.erase(deck.begin()); // 移除现在的顶部牌(原第二张牌,刚才移动过的)cout << "取出新的卡牌: ";printDeck(deck);deck.erase(deck.begin()); // 再次移除顶部牌,对应扔掉的操作cout << "移除下一张顶牌(弃牌): ";printDeck(deck);}cout << "最后一张牌为: " << deck.front().value << endl;cout << "之前步骤3,藏在屁股后面的卡牌为: " << asideCard.value << endl;return deck.front().value == asideCard.value;
}int main() {// 初始化牌堆,每张牌各有两张vector<Card> deck = { {1}, {2}, {3}, {4}, {1}, {2}, {3}, {4} };cout << "初始卡牌: ";printDeck(deck);// 模拟魔术步骤moveCardsForName(deck, 3); // 假设名字长度为3cout << "移动卡牌后的名称: ";printDeck(deck);Card asideCard = takeTopCard(deck); // 执行步骤3并记下牌堆顶的牌cout << "抽取第一张卡牌藏在屁股后面: ";printDeck(deck);cout << "藏起来的卡牌是: " << asideCard.value << endl;moveCardsByRegion(deck, 2); // 假设是北方人cout << "执行步骤4,判断南北方人: ";printDeck(deck);removeCardsByGender(deck, 'M'); // 假设是男性cout << "执行步骤5,按性别删除卡牌: ";printDeck(deck);cycleCards(deck, "见证奇迹的时刻"); // 循环移动牌cout << "执行步骤6,循环移动卡牌后: ";printDeck(deck);cout << "执行步骤7,从牌堆顶开始,每次先将牌堆顶的一张牌放在牌堆底,再扔掉牌堆顶的一张牌,重复以上操作直到只剩一张牌" << endl;// 执行最终操作并比较bool isMagicSuccessful = finalOperationAndCompare(deck, asideCard);if (isMagicSuccessful) {cout << "魔术成功!最后一张牌与预留的牌相符。" << endl;}else {cout << "魔术失败!最后一张牌与预留的牌不符。" << endl;}return 0;
}

运行结果

模拟运行结果如下: 

初始卡牌: 1 2 3 4 1 2 3 4
移动卡牌后的名称: 4 1 2 3 4 1 2 3
抽取第一张卡牌藏在屁股后面: 1 2 3 4 1 2 3
藏起来的卡牌是: 4
执行步骤4,判断南北方人: 3 4 1 2 3 1 2
执行步骤5,按性别删除卡牌: 4 1 2 3 1 2
执行步骤6,循环移动卡牌后: 2 3 1 2 4 1
执行步骤7,从牌堆顶开始,每次先将牌堆顶的一张牌放在牌堆底,再扔掉牌堆顶的一张牌,重复以上操作直到只剩一张牌
弃牌之前手里卡牌为: 2 3 1 2 4 1
将顶部卡牌移至底部: 2 3 1 2 4 1 2
取出新的卡牌: 3 1 2 4 1 2
移除下一张顶牌(弃牌): 1 2 4 1 2
弃牌之前手里卡牌为: 1 2 4 1 2
将顶部卡牌移至底部: 1 2 4 1 2 1
取出新的卡牌: 2 4 1 2 1
移除下一张顶牌(弃牌): 4 1 2 1
弃牌之前手里卡牌为: 4 1 2 1
将顶部卡牌移至底部: 4 1 2 1 4
取出新的卡牌: 1 2 1 4
移除下一张顶牌(弃牌): 2 1 4
弃牌之前手里卡牌为: 2 1 4
将顶部卡牌移至底部: 2 1 4 2
取出新的卡牌: 1 4 2
移除下一张顶牌(弃牌): 4 2
弃牌之前手里卡牌为: 4 2
将顶部卡牌移至底部: 4 2 4
取出新的卡牌: 2 4
移除下一张顶牌(弃牌): 4
最后一张牌为: 4
之前步骤3,藏在屁股后面的卡牌为: 4
魔术成功!最后一张牌与预留的牌相符。


结语

❤表演结束,你的牌对上了吗?(●'◡'●)

 

 

相关文章:

【C/C++】2024春晚刘谦春晚魔术步骤模拟+暴力破解

在这个特别的除夕夜&#xff0c;我们不仅享受了与家人的温馨团聚&#xff0c;还被电视机前的春节联欢晚会深深吸引。特别是&#xff0c;魔术师刘谦的精彩表演&#xff0c;为我们带来了一场视觉和心灵的盛宴。在我的博客“【C/C】2024春晚刘谦春晚魔术步骤模拟暴力破解”中&…...

Java运算符和表达式

Java运算符和表达式 和C语言一样&#xff0c;java也有基础的运算符和表达式&#xff0c;用来完成一些基础的数学计算&#xff0c;以及逻辑运算&#xff0c;我们一起来学习一下吧。 算数运算符 首先&#xff0c;这个算数运算符与数学中即C语言的运算符的功能一样&#xff0c;利…...

波奇学Linux:软硬链接

ln指令建立链接 软链接 硬链接 所属者的前的数字表示硬链接数&#xff0c;引用计数&#xff0c;file.txt和soft_link是软链接所以都为2 软链接有独立inode&#xff0c;硬链接没有&#xff0c;所以硬链接不是独立文件&#xff0c;软链接是独立文件&#xff0c;且硬链接的属性会…...

HTTP网络通信协议基础

目录 前言&#xff1a; 1.HTTP协议理论 1.1协议概念 1.2工作原理 1.3工作场景 2.HTTP抓包工具 2.1Fiddler工具 2.2抓包原理 2.3抓包结果 3.HTTP协议格式 3.1HTTP请求 3.2HTTP响应 3.3格式总结 前言&#xff1a; 在了解完网络编程的传输层UDP和TCP通信协议后&#…...

Java实现河南软件客服系统 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 系统管理人员2.2 业务操作人员 三、系统展示四、核心代码4.1 查询客户4.2 新增客户跟进情况4.3 查询客户历史4.4 新增服务派单4.5 新增客户服务费 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpringBootMySQL的河…...

【小沐学GIS】基于C++QT绘制三维数字地球Earth(OpenGL)

&#x1f37a;三维数字地球系列相关文章如下&#x1f37a;&#xff1a;1【小沐学GIS】基于C绘制三维数字地球Earth&#xff08;456:OpenGL、glfw、glut&#xff09;第一期2【小沐学GIS】基于C绘制三维数字地球Earth&#xff08;456:OpenGL、glfw、glut&#xff09;第二期3【小沐…...

如何生成生成一个修仙世界的狗血短剧剧本

如何生成生成一个修仙世界的狗血短剧剧本 生成一个修仙世界的狗血短剧剧本将上述剧本转为对话 生成一个修仙世界的狗血短剧剧本 剧本名称&#xff1a;《仙途情缘》 角色&#xff1a; 易天行&#xff1a;男主角&#xff0c;天赋异禀的修仙者&#xff0c;性格坚毅&#xff0c;正…...

【MIMO】

MIMO技术入门 1.简介 MIMO(多入多出):多天线技术。 注意&#xff1a;此处的多天线&#xff0c;并不是有多个天线板&#xff0c;对基站来讲指天线有多套振子&#xff08;每一套振子都可以看成一个独立的天线&#xff09;。 4G 8天线&#xff1b;5G 64T64R&#xff1b;不仅基站…...

ZooKeeper分布式锁

ZooKeeper是一个开源的分布式协调服务&#xff0c;它主要用于维护配置信息、提供分布式同步、命名服务等。ZooKeeper的数据模型类似于文件系统&#xff0c;它的数据结构中的每个数据节点称为znode&#xff0c;可以用它来实现分布式锁。 ZooKeeper分布式锁的原理&#xff1a; …...

WPF是不是垂垂老矣啦?平替它的框架还有哪些

WPF&#xff08;Windows Presentation Foundation&#xff09;是微软推出的一种用于创建 Windows 应用程序的用户界面框架。WPF最初是在2006年11月推出的&#xff0c;它是.NET Framework 3.0的一部分&#xff0c;为开发人员提供了一种基于 XAML 的方式来构建丰富的用户界面。 W…...

浅析Linux追踪技术之ftrace:Tracepoint

文章目录 概述Tracepoint使用定义Tracepoint添加Tracepoint调用 Tracepoint数据结构TRACE_EVENT实现DECLARE_TRACE__DECLARE_TRACE trace_xxx函数相关参考 概述 Tracepoint&#xff08;跟踪点&#xff09;是添加到代码流程中的调用点&#xff0c;并且允许开发者注册自定义的回…...

python ftp文件断点续传 并判断ftp文件下载完成

在Python中实现FTP文件的断点续传&#xff0c;通常涉及到以下步骤&#xff1a; 连接到FTP服务器。获取远程文件的大小。检查本地文件是否存在以及它的大小。如果本地文件不存在或大小小于远程文件&#xff0c;从上次中断的位置开始下载。下载完成后&#xff0c;检查文件大小以…...

SpringBoot+Vue3 完成小红书项目

简介 该项目采用微服务架构&#xff0c;实现了前后端分离的系统设计。在前端&#xff0c;我们选择了 Vue3 配合 TypeScript 和 ElementUi 框架&#xff0c;以提升开发效率和用户体验。而在后端&#xff0c;则是运用 SpringBoot 和 Mybatis-plus 进行开发&#xff0c;保证了系统…...

springboot集成Sa-Token及Redis的redisson客户端

文章目录 什么是Sa-Token?为什么集成Redis的redisson客户端?如何集成?maven依赖application.yml配置过滤器配置验证参考什么是Sa-Token? Sa-Token 是一个轻量级 Java 权限认证框架,主要解决:登录认证、权限认证、单点登录、OAuth2.0、分布式Session会话、微服务网关鉴权…...

SQL世界之命令语句Ⅴ

目录 一、SQL CREATE INDEX 语句 1.SQL CREATE INDEX 语句 2.SQL CREATE INDEX 语法 3.SQL CREATE UNIQUE INDEX 语法 4.SQL CREATE INDEX 实例 二、SQL 撤销索引、表以及数据库 1.SQL DROP INDEX 语句 2.SQL DROP TABLE 语句 3.SQL DROP DATABASE 语句 4.SQL TRUNCA…...

Springboot拦截器中跨域失效的问题、同一个接口传入参数不同,一个成功,一个有跨域问题、拦截器和@CrossOrigin和@Controller

Springboot拦截器中跨域失效的问题 一、概述 1、具体场景 起因&#xff1a; 同一个接口&#xff0c;传入不同参数进行值的修改时&#xff0c;一个成功&#xff0c;另一个竟然失败&#xff0c;而且是跨域问题拦截器内的request参数调用getHeader方法时&#xff0c;获取不到前端…...

WordPress如何自建txt文本经典语录并随机显示一句话经典语录?

前面跟大家分享的『WordPress集成一言&#xff08;Hitokoto&#xff09;API经典语句功能』一文中就提供有自创API&#xff0c;其中懿古今顶部左上角显示的经典语录用的就是自建一个txt文本文件&#xff0c;然后再在前端网页指定位置随机显示语录。具体操作方法如下&#xff1a;…...

Java中JVM常用参数配置(提供配置示例)

目录 前言一、内存参数配置二、垃圾收集器配置三、GC策略配置3.1、基础通用配置3.2、Parallel 和 Parallel Old 常用参数配置3.3、CMS 常用参数配置3.4、G1 常用参数配置 四、GC日志配置五、dump 日志参数配置5.1、OutOfMemory异常时生成dump文件5.2、发生Full GC时生成dump文件…...

图论与图数据应用综述:从基础概念到知识图谱与图智能

目录 前言1 图论基础概念1.1 节点度1.2 度分布1.3 邻接矩阵 2 探索图的高级概念2.1 最短路径的关键性2.2 图的直径与平均路径的意义2.3 循环与路径类型的多样性 3 深入探讨图的广泛应用领域3.1 知识图谱的知识管理3.2 图智能在复杂决策中的应用3.3 图数据挖掘与分析的多领域应用…...

知识碎片-SpringBoot统一返回结果和捕获异常

统一返回结果 定义统一返回结果类ResultResponse定义新注解ResponseResult来标记需要拦截的方法或类添加RestControllerAdvice注解&#xff0c;实现ResponseBodyAdvice接口&#xff0c;重写support, beforeBodyWrite方法 统一结果类ResultResponse Setter Getter public cla…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解

【关注我&#xff0c;后续持续新增专题博文&#xff0c;谢谢&#xff01;&#xff01;&#xff01;】 上一篇我们讲了&#xff1a; 这一篇我们开始讲&#xff1a; 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下&#xff1a; 一、场景操作步骤 操作步…...

iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版​分享

平时用 iPhone 的时候&#xff0c;难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵&#xff0c;或者买了二手 iPhone 却被原来的 iCloud 账号锁住&#xff0c;这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...

大学生职业发展与就业创业指导教学评价

这里是引用 作为软工2203/2204班的学生&#xff0c;我们非常感谢您在《大学生职业发展与就业创业指导》课程中的悉心教导。这门课程对我们即将面临实习和就业的工科学生来说至关重要&#xff0c;而您认真负责的教学态度&#xff0c;让课程的每一部分都充满了实用价值。 尤其让我…...

安卓基础(aar)

重新设置java21的环境&#xff0c;临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的&#xff1a; MyApp/ ├── app/ …...

HashMap中的put方法执行流程(流程图)

1 put操作整体流程 HashMap 的 put 操作是其最核心的功能之一。在 JDK 1.8 及以后版本中&#xff0c;其主要逻辑封装在 putVal 这个内部方法中。整个过程大致如下&#xff1a; 初始判断与哈希计算&#xff1a; 首先&#xff0c;putVal 方法会检查当前的 table&#xff08;也就…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)

船舶制造装配管理现状&#xff1a;装配工作依赖人工经验&#xff0c;装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书&#xff0c;但在实际执行中&#xff0c;工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...

【笔记】WSL 中 Rust 安装与测试完整记录

#工作记录 WSL 中 Rust 安装与测试完整记录 1. 运行环境 系统&#xff1a;Ubuntu 24.04 LTS (WSL2)架构&#xff1a;x86_64 (GNU/Linux)Rust 版本&#xff1a;rustc 1.87.0 (2025-05-09)Cargo 版本&#xff1a;cargo 1.87.0 (2025-05-06) 2. 安装 Rust 2.1 使用 Rust 官方安…...

Linux nano命令的基本使用

参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时&#xff0c;显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...

三分算法与DeepSeek辅助证明是单峰函数

前置 单峰函数有唯一的最大值&#xff0c;最大值左侧的数值严格单调递增&#xff0c;最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值&#xff0c;最小值左侧的数值严格单调递减&#xff0c;最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...

探索Selenium:自动化测试的神奇钥匙

目录 一、Selenium 是什么1.1 定义与概念1.2 发展历程1.3 功能概述 二、Selenium 工作原理剖析2.1 架构组成2.2 工作流程2.3 通信机制 三、Selenium 的优势3.1 跨浏览器与平台支持3.2 丰富的语言支持3.3 强大的社区支持 四、Selenium 的应用场景4.1 Web 应用自动化测试4.2 数据…...