新年快乐(水)

首先,祝大家新年快乐,龙年大吉!

然后我来大概解释一下春晚上两个魔术的原理吧。切,要不是我电脑坏了才不看春晚呢。

第一个魔术根数学没多大关系,主要就是换了一副牌,然后假洗。至于计时器吗,那基本就是后台改的数据了。

第二个魔术就是约瑟夫环。就是不管你是男的女的,南方北方,最后都能拼出完整的一张牌(除了尼格买提)。给你们看一个我写的破解代码。

#include <bits/stdc++.h>
using namespace std;
vector<int> card,tmp;
int head,tail,len;//队列模拟卡片(虽然用了vector)
bool find(int x){for(int i=0;i<card.size();i++){if(card[i]==x)return true;}return false;
}
void shuffle(){tmp.clear();for(int i=4;i>0;i--){srand(time(0));int idx=rand()%i;tmp.push_back(card[idx]);card.erase(card.begin()+idx);}for(int i=0;i<tmp.size();i++)card.push_back(tmp[i]);
}
int main(){head=tail=len=0;srand(time(0));while(card.size()!=4){int x=rand()%14;if(x!=0 && !find(x)){card.push_back(x);tail++;}}cout<<"随机抽4张牌,分别是";for(int i=0;i<card.size();i++){cout<<card[i];if(i!=3)cout<<',';}cout<<endl;shuffle();cout<<"打乱顺序,牌分别是";for(int i=0;i<card.size();i++){cout<<card[i];if(i!=3)cout<<',';}cout<<endl;for(int i=0;i<4;i++){card.push_back(card[i]);tail++;}cout<<"对折撕开后,牌分别是";for(int i=0;i<card.size();i++){cout<<card[i];if(i!=7)cout<<',';}cout<<endl;string name;cout<<"输入你的英文名字,也可以是你中文名字的首字母:";cin>>name;len=name.size();for(int i=0;i<len;i++){card.push_back(card[head]);head++;tail++;}cout<<"按照名字移动后,牌分别是:";for(int i=head;i<tail;i++){cout<<card[i];if(i!=(tail-1))cout<<',';}cout<<endl;tmp.clear();for(int i=0;i<3;i++){tmp.push_back(card[head]);head++;}len=tail-head;for(int i=0;i<(len/2);i++){card.push_back(card[head]);head++;tail++;}for(int i=0;i<tmp.size();i++){card.push_back(tmp[i]);tail++;}for(int i=0;i<(len-len/2);i++){card.push_back(card[head]);head++;tail++;}cout<<"将最上面三张插到剩下牌的中间后,牌分别是:";for(int i=head;i<tail;i++){cout<<card[i];if(i!=(tail-1))cout<<',';}cout<<endl;int key=card[head];head++;cout<<"藏好的牌是"<<key<<endl;int k;cout<<"南方人输1,北方人输2,其他输3:";cin>>k;tmp.clear();for(int i=0;i<k;i++){tmp.push_back(card[head]);head++;}len=tail-head;for(int i=0;i<(len/2);i++){card.push_back(card[head]);head++;tail++;}for(int i=0;i<tmp.size();i++){card.push_back(tmp[i]);tail++;}for(int i=0;i<(len-len/2);i++){card.push_back(card[head]);head++;tail++;}cout<<"在将前k(k是你刚刚输的数字)张牌插入中间后,现在的牌分别是:";for(int i=head;i<tail;i++){cout<<card[i];if(i!=(tail-1))cout<<',';}cout<<endl;string sex;cout<<"你的性别是:";cin>>sex;if(sex=="男")head++;elsehead+=2;cout<<"由于你的性别是"<<sex<<",所以弃完后剩下这些牌:";for(int i=head;i<tail;i++){cout<<card[i];if(i!=(tail-1))cout<<',';}cout<<endl;cout<<"见证奇迹的时刻"<<endl<<"把第一张牌放到末尾7次"<<endl;for(int i=0;i<7;i++){card.push_back(card[head]);head++;tail++;}cout<<"现在的牌分别是:";for(int i=head;i<tail;i++){cout<<card[i];if(i!=(tail-1))cout<<',';}cout<<endl;cout<<"好运留下来,保洁阿姨对不起!"<<endl;while((head+1)!=tail){card.push_back(card[head]);head++;tail++;head++;}cout<<"藏好的牌是"<<key<<",现在手里的牌是:";for(int i=head;i<tail;i++)cout<<card[i]<<endl;cout<<"成功啦!"<<endl;return 0;
}

那为什么这篇博客迟到了这么久?啊是因为除夕早晨我搁着那玩florr,结果磁盘莫名其妙的坏了,然后......不过现在总算是好了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/680656.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Java程序设计】【C00264】基于Springboot的原创歌曲分享平台(有论文)

基于Springboot的原创歌曲分享平台&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的原创歌曲分享平台 本系统分为平台功能模块、管理员功能模块以及用户功能模块。 平台功能模块&#xff1a;在平台首页可以查看首…

Linux系统安全——iptables相关总结

在使用iptables时注意要先关闭firewalld&#xff08;systemctl stop firewalld.service&#xff09; 1.查看iptables规则 iptables -vnL 选项含义-v查看时显示更多详细信息-n所有字段以数字形式显示-L查看规则列表 例&#xff0c;拒绝来自192.168.241.22的源地址 直接丢弃 …

可视化工具:将多种数据格式转化为交互式图形展示的利器

引言 在数据驱动的时代&#xff0c;数据的分析和理解对于决策过程至关重要。然而&#xff0c;不同的数据格式和结构使得数据的解读变得复杂和困难。为了解决这个问题&#xff0c;一种强大的可视化工具应运而生。这个工具具有将多种数据格式&#xff08;包括JSON、YAML、XML、C…

Swift Combine 用 Future 来封装异步请求 从入门到精通十一

Combine 系列 Swift Combine 从入门到精通一Swift Combine 发布者订阅者操作者 从入门到精通二Swift Combine 管道 从入门到精通三Swift Combine 发布者publisher的生命周期 从入门到精通四Swift Combine 操作符operations和Subjects发布者的生命周期 从入门到精通五Swift Com…

16 亚稳态原理和解决方案

1. 亚稳态原理 亚稳态是指触发器无法在某个规定的时间段内到达一个可以确认的状态。在同步系统中&#xff0c;输入总是与时钟同步&#xff0c;因此寄存器的setup time和hold time是满足的&#xff0c;一般情况下是不会发生亚稳态情况的。在异步信号采集中&#xff0c;由于异步…

【C++】STL之string 超详解

目录 1.string概述 2.string使用 1.构造初始化 2.成员函数 1.迭代器 2.容量操作 1.size和length 返回字符串长度 2.resize 调整字符串大小 3.capacity 获得字符串容量 4.reserve 调整容量 5.clear 清除 6.empty 判空 3.string插入、追加 、拼接 1.运算…

DataBinding源码浅析---初始化过程

作为Google官方发布的支持库&#xff0c;DataBinding实现了UI组件和数据源的双向绑定&#xff0c;同时在Jetpack组件中&#xff0c;也将DataBinding放在了Architecture类型之中。对于DataBinding的基础使用请先翻阅前两篇文章的详细阐述。本文所用代码也是建立在之前工程基础之…

利用Windows10漏洞破解密码(保姆级教学)

前言: 本篇博客只是技术分享并非非法传播知识,实验内容均是在虚拟机中进行,并非真实环境 正文: 一.windows10电脑密码破解 1)开启windows10虚拟机,停留在这个页面 2&#xff09;按5次Shift键,出现这个粘滞键,如果没有出现的,则说明漏洞已经修复 3)重新启动,在这个页面的时候…

conda 相关命令

创建并激活环境&#xff1a;打开终端&#xff0c;并创建一个新的conda环境&#xff0c;以确保安装的软件与M1芯片兼容。运行以下命令&#xff1a; conda create -n myenv python这将创建一个名为"myenv"的新环境&#xff0c;并安装Python。然后&#xff0c;激活该环境…

只用cin和cout

ios::sync_with_stdio(false)&#xff1b; ——> 在c中之所以cin&#xff0c;cout效率低&#xff0c;是因为先把要输出的东西存入缓冲区&#xff0c;再输出&#xff0c;导致效率降低&#xff0c;而这段语句可以来打消iostream的输入和输出缓存&#xff0c;可节省时间&#…

P1928 外星密码

网址如下&#xff1a; P1928 外星密码 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) C的string真的是太好用辣&#xff01; 思路就是用一个函数来递归翻译 代码如下&#xff1a; #include<iostream> #include<string> #include<cctype> using namespace…

2024/2/7 图的基础知识 1

图的存储 B3643 图的存储 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 思路&#xff1a;mp[n][n]用来存邻接矩阵&#xff0c;二维vector用来存每个点连的点 完整代码&#xff1a; #include <bits/stdc.h> #define int long long const int N 1e5 10; int n, m; …

C++重新入门-字符串

C 提供了以下两种类型的字符串表示形式&#xff1a; C 风格字符串C 引入的 string 类类型 1.C 风格字符串 C 风格字符串是使用字符数组来表示的&#xff0c;以空字符 \0 结尾。它们通常被称为 "C-style strings"。例如&#xff1a; char str[] "Hello"…

Qt4版本的信号槽写法

​​​​​​ connect(teacher,SIGNAL(hungry(QString)),student,SLOT(treat(QString))); 这里使用了SIGNAL和SLOT这两个宏&#xff0c;宏的参数是信号函数和槽函数的函数原型。 因为直接填入了函数原型&#xff0c;所有这里边编译不会出现因为重载导致的函数指针二义性的问…

CSC8014: Software Development – Advanced Techniques 第二周

2.3 Introduction to the Collections Framework The Collections Framework • A unified, generic framework for the representation and manipulation of groups of objects –Manipulation is independent of representation • Includes: –Interfaces that define typ…

QT 信号和槽的拓展

​​​​​​ 一个信号可以和多个槽相连 如果是这种情况&#xff0c;这些槽会一个接一个的被调用&#xff0c;但是槽函数调用顺序是不确定的。像上面的例子&#xff0c;可以将一个按钮点击信号连接到关闭窗口的槽函数&#xff0c;同时也连接到学生请吃饭的槽函数&#xff0c;…

服务降级(Sentinel)

服务降级 采用 @SentinelResource 注解方式实现, 必要的 依赖必须引入 以及 切面Bean 接口代码 @RequestMapping("/degrade")@SentinelResource(value = DEGRADE_RESOURCE_NAME, blockHandler = "blockHandlerForDegrade",entryType = EntryType.IN)pub…

模拟-替换数字

替换数字 题目链接 #include<iostream> #include<string.h>using namespace std;int main(){string str;string ans;cin>>str;for(int i 0;i<str.length();i){if(str[i] >48 && str[i] < 57){ans "number";}else{ans str[i]…

大模型参数高效微调(PEFT)知识

什么是微调&#xff1f;如何进行微调&#xff1f; 微调&#xff08;Fine-tuning&#xff09;是一种迁移学习的技术&#xff0c;用于在一个已经预训练好的模型基础上&#xff0c;通过进一步训练来适应特定的任务或数据集。微调可以在具有相似特征的任务之间共享知识&#xff0c…

数据库的使用方法

sqlite3 API&#xff1a; 头文件&#xff1a; #include <sqlite3.h> 编译时候要加上-lsqlite3 gcc a.c -lsqlite3 1&#xff09;sqlite3_open int sqlite3_open(const char *filename, /* Database filename (UTF-8) */ sqlite3 **ppDb /* OUT: SQLite db …