当前位置:网站首页>洗牌(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;
}
边栏推荐
猜你喜欢
关于地图GIS的一次实践整理(下) Redis的GIS实践
ClickHouse的客户端命令行参数
Live | 7.30 ApacheCon Asia 2022 IOT/IIOT topic, IoTDB PMC Qiao Jialin as the producer
从头开始实现YOLOV3
【云原生】什么是CI/CD? | CI/CD 带来的好处
Minecraft 1.18.1、1.18.2模组开发 23.3D动画盔甲制作
Nuscenes数据集总结(下)
Minecraft 1.18.1, 1.18.2 module development 23.3D animation armor production
Arduino框架下 ESP32看门狗使用示例
batch_size of deep learning foundation
随机推荐
2022-08-01:以下go语言代码输出什么?A:panic;B:5;C:6;D:编译错误。 package main import ( “fmt“ ) func main() {
Qt处理传输协议数据时QByteArray添加多字节的使用案例
CodeTON Round 2 (Div. 1 + Div. 2, Rated, Prizes!) C题
力扣 215. 数组中的第K个最大元素
浅学一下二叉树的顺序存储结构——堆
线代005
alibaba数据同步组件canal的实践整理
直播 | 7.30 ApacheCon Asia 2022 IOT/IIOT专题,IoTDB PMC 乔嘉林担任出品人
如何评价最近爆红的FastAPI?
复制延迟案例(1)-最终一致性
7亿听众背后的在线音频掘金故事
其他重要协议(DNS,ICMP,NAT,交换机)
日本痴汉打赏女主播1.5亿,结果。。。
批量--09---批量读文件入表
“数字化重构系统,搞定 CEO 是第一步”
Camtasia 2022简体中文版屏幕录像和视频编辑软件
【七夕】是时候展现专属于程序员的“浪漫”了
Luogu P2437 Bee Route
数学建模学习(76):多目标线性规划模型(理想法、线性加权法、最大最小法),模型敏感性分析
什么是接触电流怎么测?