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;
}

写在最后

相关推荐
小鸡吃米…2 分钟前
机器学习 - 精确率与召回率
人工智能·python·机器学习
学步_技术8 分钟前
多模态学习—A Survey of Multimodal Learning: Methods, Applications, and Future
人工智能·深度学习·计算机视觉
智算菩萨14 分钟前
2026年2月AI大语言模型评测全景:GPT-5.2与Claude 4.5的巅峰对决及国产模型崛起之路
人工智能·ai编程·ai写作
阿杰学AI16 分钟前
AI核心知识79——大语言模型之Knowledge Conflict(简洁且通俗易懂版)
人工智能·ai·语言模型·自然语言处理·aigc·rag·知识冲突
极客小云17 分钟前
【YOLO26教育版目标检测项目详解 - 从零开始掌握YOLO核心原理】
人工智能·yolo·目标检测
ar012321 分钟前
可视化AR巡检:工业智能化发展的新引擎
人工智能·ar
星火开发设计23 分钟前
C++ 输入输出流:cin 与 cout 的基础用法
java·开发语言·c++·学习·算法·编程·知识
沫儿笙23 分钟前
库卡机器人厚板焊接节气设备
网络·人工智能·机器人
2501_9333295523 分钟前
Infoseek数字公关AI中台:基于深度学习的全链路智能舆情处置系统架构解析与实战应用
人工智能·深度学习·系统架构
机器学习之心26 分钟前
卷积神经网络(CNN) 与SE(Squeeze-and-Excitation)注意力机制锂电池剩余寿命预测,MATLAB代码
人工智能·matlab·cnn·锂电池剩余寿命预测