当前位置:网站首页>洗牌(DAY 100)
洗牌(DAY 100)
2022-08-02 04:22:00 【张学恒】
1:题目
给定两叠纸牌 S1 和 S2,每叠恰好有 C 张牌。
每张牌的尺寸大小都完全相同,但是颜色可能不同。
下面介绍洗牌规则。
不妨设 S1 中纸牌从上到下编号依次为 a1,a2,…,aC,S2 中纸牌从上到下编号依次为 b1,b2,…,bC。
洗牌就是将这两叠牌交错堆叠在一起,形成一个拥有 2C 张牌的新牌堆 S12。
新牌堆中的牌由上至下依次为 a1,b1,a2,b2,…,aC,bC。
可参考下图:
3087_1.png
然后,将牌堆从中间一分为二,下半部分是新的 S1,上半部分是新的 S2。
这样就可以继续进行洗牌操作获得新的 S12 了。
给定 S1 和 S2,请问至少需要进行多少轮洗牌操作方可获得指定牌堆 S12。
输入格式
第一行包含一个整数 T,表示共有 T 组测试数据。
每组数据第一行包含一个整数 C。
第二行包含一个长度为 C 的由大写字母构成的字符串,其中第 i 个字母表示初始 S1 中由底向上第 i 张牌的颜色。
第三行包含一个长度为 C 的由大写字母构成的字符串,其中第 i 个字母表示初始 S2 中由底向上第 i 张牌的颜色。
第四行包含一个长度为 2C 的由大写字母构成的字符串,其中第 i 个字母表示目标 S12 中由底向上第 i 张牌的颜色。
输出格式
共 T 行,每行输出一组数据的结果,首先输出组别编号 i(从 1 开始),然后输出所需要的最少洗牌次数。如果无法通过洗牌获得目标牌堆,则输出 −1。
数据范围
1≤T≤1000,
1≤C≤100。
卡牌最多有 8 种颜色,用大写字母 A∼H 表示,所以输入字符串中不会出现其他大写字母。
输入样例:
2
4
AHAH
HAHA
HHAAAAHH
3
CDE
CDE
EEDDCC
输出样例:
1 2
2 -1
2:代码实现
```#include<bits/stdc++.h>
using namespace std;
int main(){
auto suff = [](string a, string b){
string ret;
for(int i = 0; i < (int)a.size(); i++) ret += b[i], ret += a[i];
return ret;
};
int tt; cin >> tt;
for(int _ = 1; _ <= tt; _++){
int n; cin >> n;
string s1, s2, s3;
cin >> s1 >> s2 >> s3;
int ans = 1;
set<string> mp;
for(string t = suff(s1, s2); ; t = suff(t.substr(0, n), t.substr(n, n)), ans++){
if(mp.find(t) != mp.end()) {
ans = -1; break;}
else if(t == s3) break;
else mp.insert(t);
}
cout << _ << ' ' << ans << endl;
}
return 0;
}
边栏推荐
猜你喜欢

C - The Domino Effect(dfs+回溯)

ScholarOne Manuscripts submits journal LaTeX file and cannot convert PDF successfully!

Qt FAQ

Visual SLAM Lecture Fourteen - Lecture 13 Practice: Designing a SLAM system (the most detailed code debugging and running steps)

直播 | 7.30 ApacheCon Asia 2022 IOT/IIOT专题,IoTDB PMC 乔嘉林担任出品人

“数字化重构系统,搞定 CEO 是第一步”

Arduino框架下ESP32重启原因串口信息输出示例

ClickHouse的客户端命令行参数
Deep Blue Academy - Handwritten VIO Homework - Chapter 2

JDBC再回顾
随机推荐
被大厂强制毕业,两个月空窗期死背八股文,幸好上岸,不然房贷都还不上了
A practice arrangement about map GIS (below) GIS practice of Redis
Learn about the sequential storage structure of binary tree - heap
UI自动化测试框架搭建——标记性能较差用例
开放原子开源峰会落幕,百度超级链牵头成立XuperCore开源工作组
PyQt5_pyqtgraph鼠标在折线图上画直线
复制延迟案例(1)-最终一致性
Arduino框架下STM32F1/F4系列HID模式程序烧录教程
力扣练习——43 路径总和
batch_size of deep learning foundation
acwing 最大数
EasyCVR视频广场切换通道,视频播放协议异常的问题修复
区间和 离散化
热爱责任担当
递归实现组合型枚举(DAY 92)
2022 Huawei Software Elite Challenge (Preliminary) - Summary
Platts Analysis-MATLAB Toolbox Function
捷信将ESG理念注入企业DNA致力于提供“负责任的消费金融服务”
Qt FAQ
C# Thread IsBackground作用