| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> Where is the Pizza? -> 正文阅读 |
|
[数据结构与算法]Where is the Pizza? |
While searching for the pizza, baby Hosssam came across two permutations?aa?and?bb?of length?nn. Recall that a permutation is an array consisting of?nn?distinct integers from?11?to?nn?in arbitrary order. For example,?[2,3,1,5,4][2,3,1,5,4]?is a permutation, but?[1,2,2][1,2,2]?is not a permutation (22?appears twice in the array) and?[1,3,4][1,3,4]?is also not a permutation (n=3n=3?but there is?44?in the array). Baby Hosssam forgot about the pizza and started playing around with the two permutations. While he was playing with them, some elements of the first permutation got mixed up with some elements of the second permutation, and to his surprise those elements also formed a permutation of size?nn. Specifically, he mixed up the permutations to form a new array?cc?in the following way.
You know permutations?aa,?bb, and values at some positions in?cc. Please count the number different permutations?cc?that are consistent with the described process and the given values. Since the answer can be large, print it modulo?109+7109+7. It is guaranteed that there exists at least one permutation?cc?that satisfies all the requirements. Input The first line contains an integer?tt?(1≤t≤1051≤t≤105) — the number of test cases. The first line of each test case contains a single integer?nn?(1≤n≤1051≤n≤105) — the length of the permutations. The next line contains?nn?distinct integers?a1,a2,…,ana1,a2,…,an?(1≤ai≤n1≤ai≤n) — the first permutation. The next line contains?nn?distinct integers?b1,b2,…,bnb1,b2,…,bn?(1≤bi≤n1≤bi≤n) — the second permutation. The next line contains?nn?distinct integers?d1,d2,…,dnd1,d2,…,dn?(didi?is either?00,?aiai, or?bibi) — the description of the known values of?cc. If?di=0di=0, then there are no requirements on the value of?cici. Otherwise, it is required that?ci=dici=di. It is guaranteed that there exists at least one permutation?cc?that satisfies all the requirements. It is guaranteed that the sum of?nn?over all test cases does not exceed?5?1055?105. Output For each test case, print the number of possible permutations?cc, modulo?109+7109+7. Example input Copy 9 7 1 2 3 4 5 6 7 2 3 1 7 6 5 4 2 0 1 0 0 0 0 1 1 1 0 6 1 5 2 4 6 3 6 5 3 1 4 2 6 0 0 0 0 0 8 1 6 4 7 2 3 8 5 3 2 8 1 4 5 6 7 1 0 0 7 0 3 0 5 10 1 8 6 2 4 7 9 3 10 5 1 9 2 3 4 10 8 6 7 5 1 9 2 3 4 10 8 6 7 5 7 1 2 3 4 5 6 7 2 3 1 7 6 5 4 0 0 0 0 0 0 0 5 1 2 3 4 5 1 2 3 4 5 0 0 0 0 0 5 1 2 3 4 5 1 2 3 5 4 0 0 0 0 0 3 1 2 3 3 1 2 0 0 0 output Copy 4 1 2 2 1 8 1 2 2 Note In the first test case, there are?44?distinct permutation that can be made using the process:?[2,3,1,4,5,6,7][2,3,1,4,5,6,7],?[2,3,1,7,6,5,4][2,3,1,7,6,5,4],?[2,3,1,4,6,5,7][2,3,1,4,6,5,7],?[2,3,1,7,5,6,4][2,3,1,7,5,6,4]. In the second test case, there is only one distinct permutation that can be made using the process:?[1][1]. In the third test case, there are?22?distinct permutation that can be made using the process:?[6,5,2,1,4,3][6,5,2,1,4,3],?[6,5,3,1,4,2][6,5,3,1,4,2]. In the fourth test case, there are?22?distinct permutation that can be made using the process:?[1,2,8,7,4,3,6,5][1,2,8,7,4,3,6,5],?[1,6,4,7,2,3,8,5][1,6,4,7,2,3,8,5]. In the fifth test case, there is only one distinct permutation that can be made using the process:?[1,9,2,3,4,10,8,6,7,5][1,9,2,3,4,10,8,6,7,5]. 思路:这个题是说根据c的要求将a与b能排列出多少种组合,在看题时就发现了一个可奇妙的东西,这个数确定出现过之后,在后面又出现就只能选另一个,另一个又去确定别的,它们似乎构成了环,其实就是构成了很多环,环中的一个确定,那么整个环就被确定了。那么难点来了怎样将它们变成环呢?有两种方法:1.并查集。2.邻接表。在一个环中,只要一个数确定,那么选法就被固定了;一个环中没有数固定,选择一对,那么是a的,要么是b的,也只有两种。当环的大小是1时,也就是自环,自己连自己,所以只能有一种选法。 先说并查集吧:并查集是解决元素分组问题的最简洁最优雅的数据结构之一。我们只要将上下的a b数组做链接就可以了,只要连接过的元素出现过就会接着将两块合并。没有出现过它俩就是1块。也就是将在别的地方出现的合到一块,这样就自然成了环。并查集在使用时标记的是它祖宗, 也就是好多操作都在使用查询操作,标记的都是祖宗节点 再来说邻接表:它是存图的,它是将一个数组当作下标指向另一数组的值的,这个倒没啥,特殊的在于它的遍历方式,他需要有一个数组记录出现没有,停止的时候是出现以前出现过的,这刚好不是接上了,成了环。遍历的时候是将当前的值作为下一个的下标处理的,这好像和并查集有点类似。他只要判断出现的数是否在C中出现过没有即可。环是只有单边的甚至是有指向性的,不会出现多边,不会出现一个点连多个边。 而邻接表不同,只需要分别标记每个点即可。 并查集:并查集分为3步: 1.初始化将自己的fa数组初始化为自己:
2.插入,即合并。将有关系的合并成一个集合:
3.查询,查询是否在一个集合,环,分组:
完整代码: 并查集:
邻接表:
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/1 22:50:45- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |