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

写在最后

相关推荐
小安同学iter1 分钟前
SQL50+Hot100系列(11.7)
java·算法·leetcode·hot100·sql50
_dindong8 分钟前
笔试强训:Week-4
数据结构·c++·笔记·学习·算法·哈希算法·散列表
Akamai中国11 分钟前
AI 边缘计算:决胜未来
人工智能·云计算·边缘计算·云服务
陈增林14 分钟前
基于PyQt5的AI文档处理工具
人工智能
星释20 分钟前
Rust 练习册 :Nucleotide Codons与生物信息学
开发语言·算法·rust
BeingACoder24 分钟前
【SAA】SpringAI Alibaba学习笔记(二):提示词Prompt
java·人工智能·spring boot·笔记·prompt·saa·springai
Acrelhuang31 分钟前
覆盖全场景需求:Acrel-1000 变电站综合自动化系统的技术亮点与应用
大数据·网络·人工智能·笔记·物联网
寂静山林37 分钟前
UVa 1366 Martian Mining
算法
LHZSMASH!1 小时前
神经流形:大脑功能几何基础的革命性视角
人工智能·深度学习·神经网络·机器学习
Luke Ewin1 小时前
内网私有化分布式集群部署语音识别接口
人工智能·分布式·语音识别·asr·funasr·通话语音质检·区分说话人