原题链接

题意简介

建议去原题看。这题意我表达不清楚。

大概就是给你一个 n 的排列,现在要求你进行 m 次操作。

每次操作,你会在现有的排列中删去一个数,然后选择其左边或右边的一个与之相邻的数加入 b 数组中。

然后将变成两截的数组重新连在一起,更新下标。

现在问有多少种操作方案,可以使 b 数组中恰好按顺序排列着它给定的那几个数字。

只要两个方案中任一轮删数的下标不同,就视为不同的方案。

思路分析

这道题显然是道水题。不明白为什么扔在 F。或许出题人是用脚编排题目。

其实这道题是同场 div1 的 B 题,之前写的 CF1443 D 则是 div1 的 A 题。

感觉E题更难一点。

由数字不会重复这一点上看,想要加入一个数字,就需要删去其中一个与之相邻的数字。

如果某个数字两端都是需要在其之后加入的数字,那么显然无解。

另外,在删数过后,后面的数字的下标会往前推一格。判断方案不同的依据就是被删除的下标的顺序。

如果某个数字原本另一边就有一个需要保留的数字,那么前面的所有操作都不可能改变这一点。

而如果数字的两边都可以删除,那么前面的操作依然不可能改变这一点。

每次操作实质上改变的有且只有下标和加入顺序都在它之后的数字的操作对应的 ti 。

在保证不会删掉还没加入 b 的需要的数字的前提下,记每个需要的数字可以删去的与之相邻的数的个数 c 。

不难发现答案应该是: \(\prod_{i=1}^m c_i\)

代码库

说起来这是我第一次在 memset 上吃瘪。

里头有一组数据 t=1e5 里头全是 n=2 m=1

然后我就 TLE 了。

这个故事告诉我们 t 比较大时 memset 不要乱用。

或者试一下 memset(p,0,(n+1)*sizeof(int)) 。

#include <cstdio>
#include <cstring>
typedef long long ll;
#define REG register
#define rep(i,a,b) for(REG int i=a;i<=b;i++)
const ll N=2e5+5,mod=998244353;
int n,m,A[N],B[N],p[N]; ll ans; bool vis[N];
int main(){
REG int t; scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
//memset(p,0,sizeof(p));
//memset(vis,0,sizeof(vis));
rep(i,1,n) p[i]=vis[i]=0;
rep(i,1,n) scanf("%d",A+i),p[A[i]]=i;
rep(i,1,m) scanf("%d",B+i),vis[B[i]]=1;
ans=1;
rep(i,1,m){
REG int pos=p[B[i]],c=0;
if(pos-1>=1&&!vis[A[pos-1]]) c++;
if(pos+1<=n&&!vis[A[pos+1]]) c++;
ans=ans*c%mod; vis[B[i]]=0;
}
printf("%lld\n",ans);
}
return 0;
}

【CF1443F】Identify the Operations 题解的更多相关文章

  1. codechef Row and Column Operations 题解

    版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/,未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...

  2. Codeforces Round #681 (Div. 1, based on VK Cup 2019-2020 - Final) B. Identify the Operations (模拟,双向链表)

    题意:给你一组不重复的序列\(a\),每次可以选择一个数删除它左边或右边的一个数,并将选择的数append到数组\(b\)中,现在给你数组\(b\),问有多少种方案数得到\(b\). 题解:我们可以记 ...

  3. Codeforces Round #681 (Div. 2, based on VK Cup 2019-2020 - Final)【ABCDF】

    比赛链接:https://codeforces.com/contest/1443 A. Kids Seating 题意 构造一个大小为 \(n\) 的数组使得任意两个数既不互质也不相互整除,要求所有数 ...

  4. Leetcode-283 Move Zeroes

    #283.   Move Zeroes Given an array nums, write a function to move all 0's to the end of it while mai ...

  5. Cheatsheet: 2013 10.09 ~ 10.23

    Other 10 Basic Linux Networking and Monitoring Commands You Should Know A simple, portable yet effic ...

  6. 6.4 操作契约 Operation Contracts

    4.操作契约 Operation Contracts  “用例描述”的补充  强调: 用例中重要的动作,其开始与结束是需要一些约束 4.5 操作契约的后置条件  定义Definition  后 ...

  7. Oracle ASM 相关的 视图(V$) 和 数据字典(X$)

    本文转自: http://blog.csdn.net/tianlesoftware/article/details/6733039 ASM由于其高度的封装性,使得我们很难知道窥探其内部的原理.可以通过 ...

  8. Snoop resynchronization mechanism to preserve read ordering

    A processor employing a post-cache (LS2) buffer. Loads are stored into the LS2buffer after probing t ...

  9. UML期末绘图及细节总结

    往届期末绘图的题目例如以下所看到的: Read the providing materials carefully, and then do tasks. 2.1: Use Case Diagram ...

随机推荐

  1. 李宏毅老师机器学习第一课Linear regression

    机器学习就是让机器学会自动的找一个函数 学习图谱: 1.regression example appliation estimating the combat power(cp) of a pokem ...

  2. Python练习题 036:Project Euler 008:1000位数字中相邻13个数字最大的乘积

    本题来自 Project Euler 第8题:https://projecteuler.net/problem=8 # Project Euler: Problem 8: Largest produc ...

  3. 2020.09.05【NOIP提高组&普及组】模拟赛C组1总结

    T1:机器翻译 这一道题是一个很简单的队列题目,我们只要每次维护队列元素数量保持在m以内即可 T2:乌龟棋 这一道题我一开始比赛是暴力枚举(万事先暴力),很明显这个肯定会超时(30分)那么考虑动态规划 ...

  4. Python3基础——序列类型

    开头写给自己,To Myself: 很久以来,都想要学习一门编程语言,从去年选择了python开始,反反复复重新开始了N多遍,每一次不会超过俩星期.昨天无意间翻开自己去年记的学习笔记,不禁感叹想当年我 ...

  5. python-格式化(%,format,f-string)输出+输入

    1-格式化输出: % 1.print('我的姓名是%s,身高%s cm'%(name,height)) 2.%s -str() ; %d–十进制3.传入值的时候一定是个元组,不是列表4.当指定长度时: ...

  6. 看动画学算法之:linkedList

    目录 简介 linkedList的构建 linkedList的操作 头部插入 尾部插入 中间插入 删除节点 简介 linkedList应该是一种非常非常简单的数据结构了.节点一个一个的连接起来,就成了 ...

  7. 诊断日志知多少 | DiagnosticSource 在.NET上的应用

    1. 引言 最近为了解决ABP集成CAP时无法通过拦截器启用工作单元的问题,从小伙伴那里学了一招.借助DiagnossticSource,可以最小改动完成需求.关于DiagnosticSource晓东 ...

  8. Java基础系列-RandomAccess

    原创文章,转载请标注出处:https://www.cnblogs.com/V1haoge/p/10755424.html Random是随机的意思,Access是访问的意思,合起来就是随机访问的意思. ...

  9. 【Zabbix】在CentOS 7上搭建Zabbix服务,收集Windows客户端计数器性能数据(含过程中遇到的问题解决方法)

    1.环境 1.1.关闭防火墙 命令:systemctl stop firewalld 或者 systemctl stop firewalld.service (备注:相应的,若要开启防火墙,将对应的& ...

  10. vue获取下拉框select的值

    1.我写的是循环遍历,然后获取id :value="v.id"这就是获取的id然后打印就可以获取id了