2022 RoboCom 世界机器人开发者大赛-本科组(省赛)解题报告 | 珂学家


前言


题解

2022 RoboCom 世界机器人开发者大赛-本科组(省赛)。

感觉T5是最简单的,其他都不好做。


RC-u5 树与二分图

分值: 30分

思路: 容斥原理

树天然就是二分图,按深度d归类(偶数深度为S1,奇数深度为S2),如果新增边,还是二分图,说明

新增边 ( u , v ) , u ∈ S 1 , v ∈ S 2 新增边(u, v), u\in S1, v\in S2 新增边(u,v),u∈S1,v∈S2

只要能梳理出这个性质,那这题就非常的容易。

由容斥得

∣ S 1 ∣ ∗ ∣ S 2 ∣ − ( n − 1 ) |S1| * |S2| - (n - 1) ∣S1∣∗∣S2∣−(n−1)
n 为树的节点, n − 1 为树的边数 n 为树的节点, n-1为树的边数 n为树的节点,n−1为树的边数

S1和S2通过DFS或者bfs层序遍历即可

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

int color[2] = {0};

void dfs(vector<vector<int>>&g, vector<int>&color, int u, int fa, int c) {
    color[c]++;
    for (int v: g[u]) {
        if (v == fa) continue;
        dfs(g, color, v, u, 1 - c);
    }
}

int main() {
    int n;
    cin >> n;
    vector<vector<int>> g(n);
    vector<int> color(n);
    for (int i = 0; i < n - 1; i++) {
        int u, v;
        cin >> u>> v;
        u--; v--;
        g[u].push_back(v);
        g[v].push_back(u);
    }
    dfs(g, color, 0, -1, 0);

    int64_t p = (int64_t)color[0] * color[1];
        
    cout << (p-(n - 1)) << "\n";
    return 0;
}

写在最后

相关推荐
宝杰X743 分钟前
Compose Multiplatform+Kotlin Multiplatfrom 第七弹跨平台 AI开源
人工智能·开源·kotlin
Java樱木43 分钟前
AI 编程 Trae ,有重大更新!用 Trae 做了个图书借阅网站!
人工智能·ai编程
悟乙己1 小时前
大型语言模型(LLM)文本中提取结构化信息:LangExtract(一)
人工智能·语言模型·自然语言处理
Theodore_10221 小时前
机器学习(3)梯度下降
人工智能·机器学习
LiJieNiub2 小时前
YOLOv3:目标检测领域的经典革新
人工智能·计算机视觉·目标跟踪
yanxing.D2 小时前
OpenCV轻松入门_面向python(第六章 阈值处理)
人工智能·python·opencv·计算机视觉
霍格沃兹测试开发学社测试人社区3 小时前
新手指南:通过 Playwright MCP Server 为 AI Agent 实现浏览器自动化能力
运维·人工智能·自动化
JJJJ_iii3 小时前
【机器学习01】监督学习、无监督学习、线性回归、代价函数
人工智能·笔记·python·学习·机器学习·jupyter·线性回归
Han.miracle4 小时前
数据结构——二叉树的从前序与中序遍历序列构造二叉树
java·数据结构·学习·算法·leetcode
qq_416276425 小时前
LOFAR物理频谱特征提取及实现
人工智能