当前位置:网站首页>2022杭电多校第三场 L题 Two Permutations
2022杭电多校第三场 L题 Two Permutations
2022-08-05 00:18:00 【Rain Sure】
题目链接
题目大意
给定两个长度为 n n n的排列 a , b a,b a,b和一个由两个排列组成的长度为 2 ∗ n 2*n 2∗n的数组 c c c,每次从两个排列中任意一个的最左端取出一个数放到 c [ i ] c[i] c[i]里,请问构造出 c c c数组的方案数。
题解
比赛的时候想了线性DP的做法,感觉很牛逼。后来看题解,发现大家的做法更优秀。。。尤其是jiangly的模拟大法,让我大受震撼!!!
设 f [ i ] [ j ] [ k ] f[i][j][k] f[i][j][k] 表示第 i i i个数从 j j j数组中选, i − 1 i - 1 i−1个数从 k k k数组中选,还需要一个额外的数组 g g g记录选择哪个数组。具体转移看代码~ ( 0 < = j < = 1 ) ( 0 < = k < = 1 ) (0 <= j <= 1) (0 <= k <= 1) (0<=j<=1)(0<=k<=1)
代码
#include<iostream>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
#define IOS ios::sync_with_stdio(false); cin.tie(0);cout.tie(0);
#define x first
#define y second
#define endl '\n'
const int inf = 1e9 + 10;
const int maxn = 300010, M = 2000010;
const int mod = 998244353;
typedef pair<int,int> PII;
typedef long long LL;
typedef unsigned long long ULL;
typedef long double LD;
int h[maxn], e[M], w[M], ne[M], idx;
int dx[4] = {
-1, 0, 1, 0}, dy[4] = {
0, -1, 0, 1};
int cnt;
void add(int a, int b, int c)
{
e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx ++;
}
void add(int a, int b)
{
e[idx] = b, ne[idx] = h[a], h[a] = idx ++;
}
int n;
int a[maxn], b[maxn], c[maxn * 2];
int f[maxn * 2][2][2];
int g[maxn * 2][2][2];
int main()
{
int t; scanf("%d", &t);
while(t --)
{
scanf("%d", &n);
for(int i = 1; i <= n; i ++) scanf("%d", &a[i]);
for(int i = 1; i <= n; i ++) scanf("%d", &b[i]);
for(int i = 1; i <= n * 2; i ++) scanf("%d", &c[i]);
memset(f, 0, sizeof f); memset(g, 0, sizeof g);
if(c[1] == a[1] && c[2] == a[2]) {
f[2][0][0] = 1;
g[2][0][0] = 2;
}
if(c[1] == a[1] && c[2] == b[1]){
f[2][1][0] = 1;
g[2][1][0] = 1;
}
if(c[1] == b[1] && c[2] == a[1]){
f[2][0][1] = 1;
g[2][0][1] = 1;
}
if(c[1] == b[1] && c[2] == b[2]){
f[2][1][1] = 1;
g[2][1][1] = 0;
}
for(int i = 3; i <= n * 2; i ++){
// f[i][0][0]
int id0 = g[i - 1][0][0], id1 = g[i - 1][0][1];
// cout << id0 << ' ' << id1 << endl;
if(a[id0 + 1] == c[i]) f[i][0][0] = (f[i][0][0] + f[i - 1][0][0]) % mod, g[i][0][0] = id0 + 1;
if(a[id1 + 1] == c[i]) f[i][0][0] = (f[i][0][0] + f[i - 1][0][1]) % mod, g[i][0][0] = id1 + 1;
// f[i][0][1]
id0 = g[i - 1][1][0], id1 = g[i - 1][1][1];
if(a[id0 + 1] == c[i]) f[i][0][1] = (f[i][0][1] + f[i - 1][1][0]) % mod, g[i][0][1] = id0 + 1;
if(a[id1 + 1] == c[i]) f[i][0][1] = (f[i][0][1] + f[i - 1][1][1]) % mod, g[i][0][1] = id1 + 1;
// f[i][1][0]
id0 = g[i - 1][0][0], id1 = g[i - 1][0][1];
if(b[(i - id0)] == c[i]) f[i][1][0] = (f[i][1][0] + f[i - 1][0][0]) % mod, g[i][1][0] = id0;
if(b[i - id1] == c[i]) f[i][1][0] = (f[i][1][0] + f[i - 1][0][1]) % mod, g[i][1][0] = id1;
// f[i][1][1]
id0 = g[i - 1][1][0], id1 = g[i - 1][1][1];
if(b[i - id0] == c[i]) f[i][1][1] = (f[i][1][1] + f[i - 1][1][0]) % mod, g[i][1][1] = id0;
if(b[i - id1] == c[i]) f[i][1][1] = (f[i][1][1] + f[i - 1][1][1]) % mod, g[i][1][1] = id1;
}
int res = 0;
for(int i = 0; i < 2; i ++){
for(int j = 0; j < 2; j ++){
res = (res + f[n * 2][i][j]) % mod;
}
}
printf("%d\n", res);
}
return 0;
}
边栏推荐
- .net (C#) get year month day between two dates
- 【LeetCode】图解 904. 水果成篮
- 标识符、关键字、常量 和变量(C语言)
- 简单的顺序结构程序(C语言)
- 测试经理要不要做测试执行?
- could not build server_names_hash, you should increase server_names_hash_bucket_size: 32
- E - Many Operations (按位考虑 + dp思想记录操作后的结果
- Implementation principle of golang coroutine
- 软件开发工具的技术要素
- 【unity编译器扩展之模型动画拷贝】
猜你喜欢
What is next-generation modeling (with learning materials)
简单的顺序结构程序(C语言)
看图识字,DELL SC4020 / SCv2000 控制器更换过程
jenkins发送邮件系统配置
《MySQL入门很轻松》第2章:MySQL管理工具介绍
论文解读( AF-GCL)《Augmentation-Free Graph Contrastive Learning with Performance Guarantee》
元宇宙:未来我们的每一个日常行为是否都能成为赚钱工具?
Essential knowledge for entry-level 3D game modelers
刘润直播预告 | 顶级高手,如何创造财富
TinyMCE禁用转义
随机推荐
软件测试面试题:一套完整的测试应该由哪些阶段组成?
Brainstorm: Complete Backpack
2 用D435i运行VINS-fusion
gorm的Raw与scan
软件测试面试题:做好测试计划的关键是什么?
Privacy Computing Overview
jenkins发送邮件系统配置
leetcode:266. 回文全排列
【云原生--Kubernetes】Pod控制器
What is next-generation modeling (with learning materials)
could not build server_names_hash, you should increase server_names_hash_bucket_size: 32
Couple Holding Hands [Greedy & Abstract]
10 种常见的BUG分类
[230]连接Redis后执行命令错误 MISCONF Redis is configured to save RDB snapshots
倒计时1天!8月2日—4日与你聊聊开源与就业那些事!
测试经理要不要做测试执行?
性能测试如何准备测试数据
Statistical words (DAY 101) Huazhong University of Science and Technology postgraduate examination questions
【LeetCode】图解 904. 水果成篮
软件测试面试题:网络七层协仪具体?