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

写在最后

相关推荐
用户24003619235001 分钟前
一文弄懂大模型RAG
人工智能·llm
你真会3 分钟前
【数据结构知识分享】顺序表详解
数据结构·学习·算法
EnochChen_5 分钟前
计算A图片所有颜色占B图片红色区域的百分比
人工智能·opencv·计算机视觉
清醒的兰9 分钟前
OpenCV 滑动条调整图像对比度和亮度
人工智能·opencv·计算机视觉
未来智慧谷23 分钟前
华为盘古 Ultra MoE 模型:国产 AI 的技术突破与行业影响
人工智能·华为
qq_4369621829 分钟前
奥威BI+AI数据分析:企业数智化转型的加速器
人工智能·数据挖掘·数据分析
manduic30 分钟前
国产高性能pSRAM选型指南:CSS6404LS-LI 64Mb QSPI伪静态存储器
人工智能·psram·国产sram·爱普psram·aps6404l-3sqr·spi sram·spi psram
@蓝莓果粒茶1 小时前
LeetCode第245题_最短单词距离III
c语言·c++·笔记·学习·算法·leetcode·c#
jndingxin1 小时前
OpenCV CUDA模块图像处理------双边滤波的GPU版本函数bilateralFilter()
图像处理·人工智能·opencv
西猫雷婶1 小时前
深度学习|pytorch基本运算-乘除法和幂运算
人工智能·pytorch·深度学习