码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • NC236758 占领城市 (最小路径点覆盖)


    题目描述
    Intercept在玩一种游戏,游戏中有 n 座城市,城市之间用单向的道路连接,形式化地说,n 座城市构成了一个有向无环图。Intercept可以控制一些毁灭机器人,对于每一个毁灭机器人,Intercept可以让它从任意一座城市出发,沿着道路以任意的路径移动,在任意一座城市停止。毁灭机器人每经过一座城市,这座城市都会被占领。但是,任意两个毁灭机器人不能经过同一座城市,因为毁灭机器人也会消灭毁灭机器人。Intercept想知道,他至少需要准备多少毁灭机器人,才能占领所有城市。
    注意:因为Intercept可以在所有点都设置一个毁灭机器人,所以一定是有解的。
    题目链接:
    https://ac.nowcoder.com/acm/problem/236758
    思路:
    拆点思想,将每个点拆成入点和出点。
    初始时,假设每个未拆的点都放置一个机器人,那么拆点后,每一次匹配就意味着这两个城市可以共用一个机器人。那么机器人数量就可以相较于之前 -1。
    那么我们希望公用的机器人越多越好,也就是最大匹配。
    最后的结果就是n-最大匹配。
    类似题目:
    Acwing 379. 捉迷藏
    是最小路径重复点覆盖问题
    题解:https://blog.csdn.net/weixin_50616227/article/details/125787640?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522165934079416781647596413%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=165934079416781647596413&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2blogfirst_rank_ecpm_v1~rank_v31_ecpm-1-125787640-null-null.nonecase&utm_term=%E6%8D%89%E8%BF%B7%E8%97%8F&spm=1018.2226.3001.4450
    代码:

    #include
    #include
    #include
    using namespace std;
    bitset<510>g[510];
    bool st[510];
    int n,m;
    int match[510];
    bool find(int u)
    {
        for(int i=1;i<=n;i++)
        {
            if(!g[u][i])
            {
                continue;
            }
            if(st[i])
            {
                continue;
            }
            st[i]=true;
            if(match[i] == -1 || find(match[i]))
            {
                match[i]=u;
                return true;
            }
        }
        return false;
    }
    int main()
    {
        memset(match,-1,sizeof match);
        cin>>n>>m;
        for(int i=0;i<m;i++)
        {
            int x,y;
            cin>>x>>y;
            g[x][y]=true;
        }
        int res=0;
        for(int i=1;i<=n;i++)
        {
            memset(st,false,sizeof st);
            if(find(i))
            {
                res++;
            }
        }
        cout<<n-res<<endl;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
  • 相关阅读:
    点赞、收藏必读文章--数据分析的多变量分析
    【gmail注册教程】手把手教你注册Google邮箱账号
    我今天拆了个炸弹
    线下门店如何根据员工排班情况给客户预约
    反射型XSS靶场练习
    【五:Spring MVC】
    Unity贪吃蛇改编【详细版】
    Visual Studio Code 快捷键大全
    【Fusion360】常用快捷键和技巧
    流式结构化数据计算语言的进化与新选择
  • 原文地址:https://blog.csdn.net/weixin_50616227/article/details/126103171
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号