华为OD统一考试A卷+B卷 新题库说明
2023年5月份,华为官方已经将的 2022/0223Q(1/2/3/4)统一修改为OD统一考试(A卷)和OD统一考试(B卷)。
你收到的链接上面会标注A卷还是B卷。请注意:根据反馈,目前大部分收到的都是B卷。但是仍有概率抽到A卷。
A卷对应2023的新题库(2022Q4 20223Q1) B卷对应20022部分考题以及新出的题目
专栏:2023华为OD机试(A卷+B卷)(C++JavaJSPy)
题目描述
给定两个数组a,b,若a[i] == b[j] 则称 [i, j] 为一个二元组,求在给定的两个数组中,二元组的个数。
输入描述
第一行输入 m
第二行输入m个数,表示第一个数组
第三行输入 n
第四行输入n个数,表示第二个数组
输出描述
二元组个数。
用例
输入 | 4 1 2 3 4 1 1 |
输出 | 1 |
说明 | 二元组个数为 1个 |
输入 | 6 1 1 2 2 4 5 3 2 2 4 |
输出 | 5 |
说明 | 二元组个数为 5 个。 |
题目解析
简单题,用双重for循环,就可以得到结果,复杂度是O(n*m)。但是在如果数组的数量特别大的话,可能会超时。
可以采用空间换时间。定义一个字典存储元素以及元素出现的次数。
C++
#</