P8889 狠狠地切割 ——哈希表离散化
创始人
2024-04-23 13:18:54
0

题目描述

现给你一个长度为 nn 的序列 a1,⋯ ,ana1​,⋯,an​ 和 mm 个互不相同的整数 b1,⋯ ,bmb1​,⋯,bm​。你需要按照这 mm 个数对序列 aa 进行狠狠地切割

具体的,对于一个数字 i∈[1,n]i∈[1,n],如果存在一个整数 j∈[1,m]j∈[1,m],使得 ai=bjai​=bj​,则将位置 ii 称为一个切割点。对序列 aa 中的每一个切割点,我们在这个位置进行一次狠狠地切割。方法是,将该位置的数字去除,然后在这个位置将其左右的序列/片段一分两半。

如果对狠狠地切割的定义有疑问,可以参照「样例 #1」及「样例解释 #1」进行理解。

你需要计算,在进行了所有可能的狠狠地切割后,序列被切割为了多少片段

特别的,如果在切割后,某一段内没有数组,那这一段不可被叫做片段。同样的,如果 11 或 nn 为切割点,其与开头和结尾之间也不存在片段。

如果对片段的概念有疑问,可以参照「样例 #2」及「样例解释 #2」进行理解。

输入格式

第一行为两个整数,依次表示序列 aa 的长度 nn 和序列 bb 的长度 mm。
第二行有 nn 个整数,第 ii 个整数表示 aiai​。
第三行有 mm 个整数,第 ii 个整数表示 bibi​。

输出格式

输出一个整数,代表狠狠地切割后的片段的个数。

输入输出样例

输入 #1

6 2
3 4 3 5 2 6
5 4

输出 #1

3

输入 #2

6 3
3 4 3 5 2 6
3 5 6

输出 #2

2
#include 
#include 
#define bug cout << "***************" << endl
#define fuck(x) cout << #x << " -> " << x << endl
#define endl '\n'
#define int long long
using namespace std;
constexpr int N = 6e6 + 10, inf = 0x3f3f3f3f;
int a[N];
bool vis[N];
unordered_map mp;
int cnt = 0;
int get(int x)
{if (mp.count(x) == 0){mp[x] = ++cnt;}return mp[x];
}
void solve()
{int m, n;int read;cin >> m >> n;for (int i = 1; i <= m; i++){cin >> read;a[i] = get(read);}for (int i = 1; i <= n; i++){cin >> read;vis[get(read)] = true;}int first = true;int ans = 0;for (int i = 1; i <= m; i++){if (!vis[a[i]] && first == true){first = false;ans++;}else if (vis[a[i]]){first = true;}}cout << ans << endl;
}signed main()
{ios_base::sync_with_stdio(0), cin.tie(0), cout.tie(0);int T = 1;while (T--){solve();}return 0;
}

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...