蓝桥杯2024年第十五届省赛真题-团建

题目描述

小蓝正在和朋友们团建,有一个游戏项目需要两人合作,两个人分别拿到一棵大小为 n 和 m 的树,树上的每个结点上有一个正整数权值。

两个人需要从各自树的根结点 1 出发走向某个叶结点,从根到这个叶结点的路径上经过的所有结点上的权值构成了一个正整数序列,两人的序列的最长公共前缀即为他们的得分。给出两棵树,请计算两个人最多的得分是多少。

输入格式

输入的第一行包含两个正整数 n, m ,用一个空格分隔。

第二行包含 n 个正整数 c1, c2, · · · , cn ,相邻整数之间使用一个空格分隔,其中 ci 表示第一棵树结点 i 上的权值。

第三行包含 m 个正整数 d1, d2, · · · , dm ,相邻整数之间使用一个空格分隔,其中 di 表示第二棵树结点 i 上的权值。接下来 n − 1 行,每行包含两个正整数 ui, vi 表示第一棵树中包含一条 ui 和vi 之间的边。

接下来 m − 1 行,每行包含两个正整数 pi, qi 表示第二棵树中包含一条 pi和 qi 之间的边。

输出格式

输出一行包含一个整数表示答案。

样例输入复制

2 2

10 20

10 30

1 2

2 1

样例输出复制

1

提示

【样例说明】两个序列可以为 [10, 20] , [10, 30] ,最大前缀为 1 ;

【样例输入】

5 4

10 20 30 40 50

10 40 20 30

1 2

1 3

2 4

3 5

1 2

1 3

3 4

【样例输出】

2

【样例说明】

两个序列可以为 [10, 20, 40] , [10, 20, 30] ,最大前缀为 2 。

【评测用例规模与约定】

对于 20% 的评测用例,1 ≤ n, m ≤ 500 ;对于所有评测用例,1 ≤ n, m ≤ 2 × 105,1 ≤ ci, di ≤ 108 ,1 ≤ ui, vi ≤ n ,1 ≤ pi, qi ≤ m ,对于任意结点,其儿子结点的权重互不相同。

1.分析

对于任意结点,其儿子结点的权重互不相同,并不代表没有相同的元素。

存储用深搜即可。

2.代码

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
#include<unordered_map>
using namespace std;
const int MAX = 2e5 + 100;
vector<int> c[MAX], d[MAX];
int n, m;
int a[MAX], b[MAX], re;

void dfs(int num,int x,int y,int fa_x,int fa_y) {
    re = max(re, num);
    unordered_map<int, int> t;
    for (auto it : c[x]) {
       if (it!=fa_x) {
           t[a[it]] = it;
       }
    }
    for (auto it : d[y]) {
        if (it != fa_y) {
            if (t.count(b[it])) {          //如果存在就向下走
                dfs( num + 1,t[b[it]], it, x, y);
            }
        }
    }
}
int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) cin >> a[i];
    for (int i = 1; i <= m; i++) cin >> b[i];
    for (int i = 1; i < n; i++) {
        int x, y;
        cin >> x >> y;
        c[x].push_back(y);
        c[y].push_back(x);
    }
    for (int i = 1; i < m; i++) {
        int x, y;
        cin >> x >> y;
        d[x].push_back(y);
        d[y].push_back(x);
    }
    if (a[1] == b[1])  dfs(1, 1, 1,0,0);
    else re = 0;
    cout << re << endl;
    return 0;
}
相关推荐
啊我不会诶2 小时前
蓝桥杯练习 混乱的数组
c++·蓝桥杯
XH华2 小时前
备战蓝桥杯,第八章:位运算符和操作符属性
职场和发展·蓝桥杯
_OP_CHEN4 小时前
【算法基础篇】(五十四)解析错排问题:从信封错位到编程实战,一次性搞懂排列组合中的 “反常识” 难题!
算法·蓝桥杯·c/c++·组合计数·算法竞赛·acm/icpc·错排问题
仰泳的熊猫1 天前
题目1434:蓝桥杯历届试题-回文数字
数据结构·c++·算法·蓝桥杯
沧澜sincerely1 天前
蓝桥杯算法练习
算法·职场和发展·蓝桥杯
_OP_CHEN1 天前
【算法基础篇】(五十三)隔板法指南:从 “分球入盒” 到不定方程,组合计数的万能解题模板
算法·蓝桥杯·c/c++·组合数学·隔板法·acm/icpc
XH华2 天前
备战蓝桥杯,第七章:函数与递归
职场和发展·蓝桥杯
仰泳的熊猫2 天前
题目1433:蓝桥杯2013年第四届真题-危险系数
数据结构·c++·算法·蓝桥杯·深度优先·图论
说给风听.2 天前
拆解蓝桥杯红黑树:无限深度树的奇偶性规律与 Python 实战解法
python·职场和发展·蓝桥杯
代码雕刻家3 天前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯