最小路径覆盖问题

news/2025/2/25 21:06:45/文章来源:https://www.cnblogs.com/watersail/p/18737253
  • 有向无环图的最小路径点覆盖——网络流方法+方案构造
#include <bits/stdc++.h>
using namespace std;
int to[20005],e[20005],nx[20005],h[305],cur[305],r[155],tot;
bool v[155];
void add(int u,int v,int w)
{tot++;to[tot]=v;e[tot]=w;nx[tot]=h[u];h[u]=tot;
}
int s,t,flow;
int d[305],n,m;
bool bfs()
{queue<int>q;memset(d,0,sizeof(int)*(t-s+1));q.push(s);d[s]=1;while(q.size()){int n1=q.front();q.pop();cur[n1]=h[n1];for(int i=h[n1];i;i=nx[i]){int y=to[i];if(!d[y]&&e[i]){d[y]=d[n1]+1;q.push(y);}}}return d[t];
}
int dinic(int n1,int flow)
{if(n1==t){return flow;}int rest=flow;for(int i=cur[n1];i&&rest;i=nx[i]){cur[n1]=i;int y=to[i];if(e[i]&&d[y]==d[n1]+1){int k=dinic(y,min(rest,e[i]));if(k==0){d[y]=0;}rest-=k;e[i]-=k;e[i^1]+=k;}}return flow-rest;
}
int main()
{ios::sync_with_stdio(false);cin.tie(0);cin>>n>>m;tot=1;for(int i=1;i<=m;i++){int u,v;cin>>u>>v;add(u,v+n,1);add(v+n,u,0);}s=0,t=2*n+1;for(int i=1;i<=n;i++){add(s,i,1);add(i,s,0);add(i+n,t,1);add(t,i+n,0);}while(bfs()){flow+=dinic(s,INT_MAX);}for(int i=n+1;i<=2*n;i++){for(int j=h[i];j;j=nx[j]){if(to[j]>=1&&to[j]<=n&&e[j]){r[to[j]]=i-n;v[i-n]=true;}}}for(int i=1;i<=n;i++){if(v[i]==false){int p=i;while(p){cout<<p<<" ";p=r[p];}cout<<endl;}}cout<<n-flow<<endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/889753.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring复习-事务

事务概述 Spring事务编程概述 事务是开发中必不可少的东西,使用JDBC开发时,我们使用connnection对事务进行控制,使用MvBatis时,我们使用SqlSession对事务进行控制,缺点显而易见,当我们切换数据库访问技术时,事务控制的方式总会变化,Spring 就将这些技术基础上,提供了统…

Prompt进阶

在Prompt入门里,我们分享了OpenAI官方给出的提示词建议,但这些建议基本上是指导性的,方向性的,概念性的,虽然对我们编写提示词有很大帮助,但究竟我们的提示词好还是不好,效率怎么性,很大程度上要看每个人的理解,和提示词输出。那么有没有一个可操作性的,方法论的,谁…

P1174 打砖块

链接 https://www.luogu.com.cn/problem/P1174 思路刚开始的思路:设置dp[i][j]:前i列使用了j颗子弹,那么递推dpi,j=max(dpi,j,dpi-1,k+maxj-k),然后统计在第i列使用了j-k颗子弹会多出来多少颗,把这些遍历加到前面,见代码。喜提70pts。但是搞不懂哪里错了。 看了评论区的dp:70…

redis - [06] redis-benchmark性能测试

题记部分 001 || 参数含义 002 || 测试100个并发,100000个请求 启动redis-server redis-server /etc/redis.conf 进行性能测试 redis-benchmark -h localhost -p 6379 -c 100 -n 100000

百万架构师第四十三课:Nginx:Nginx 应用实战|JavaGuide

百万架构师系列文章阅读体验感更佳 原文链接:https://javaguide.net 公众号:不止极客 课程目标:Nginx 反向代理功能配置 Nginx 负载均衡实战 Nginx 动静分离配置 Nginx 配置文件分析 Nginx 多进程模型原理 Nginx 高可用集群实战反向代理​ 我们把请求发送到 proxy (代理服务…

大三下每日打卡003

今天配置了python的虚拟环境anaconda想尝试一下yolov8来实现识别

需求评审

需求评审是产品经理日常会议的形式之一,也是一个“公开处刑”的时刻。这篇文章,我们看看作者分享的如何做好一次需求评审的经验,供大家参考。前段时间有小伙伴留言,想聊一下关于需求评审面向不同角色如何处理,以及产品不同生命周期产品工作上有什么区别。我结合自己工作经…

牛客题解 | 对称的二叉树_1

牛客题库题解题目 题目链接 题目的主要信息:判断一棵二叉树是否是镜像,即判断二叉树是否是轴对称图形轴对称:非轴对称:举一反三: 学习完本题的思路你可以解决如下题目: BM28. 二叉树的最大深度 BM29. 二叉树中和为某一值的路径(一) BM32. 合并二叉树 BM33. 二叉树的镜像…

牛客题解 | 字符串变形

牛客题库题解题目 题目链接 题目主要信息:将字符串大小写反转 将整个字符串的所有单词位置反转举一反三: 学会了本题的思路,你将可以解决类似的字符串问题: BM84. 最长公共前缀 BM85. 验证IP地址 方法一:双逆转(推荐使用) 思路: 将单词位置的反转,那肯定前后都是逆序,…

牛客题解 | 在二叉树中找到两个节点的最近公共祖先

牛客题库题解题目 题目链接 题目的主要信息:给定一棵二叉树以及这棵树上的两个节点对应的val值 o1 和 o2,请找到 o1 和 o2 的最近公共祖先节点 二叉树非空,且每个节点值均不同举一反三: 学习完本题的思路你可以解决如下题目: BM29. 二叉树中和为某一值的路径(一) BM37. …

牛客题解 | 反转链表_1

牛客题库题解题目 题目链接 题目的主要信息:给定一个长度为\(n\)的链表,反转该链表,输出表头举一反三: 学习完本题的思路你可以解决如下题目: JZ6. 从尾到头打印链表 方法一:迭代(推荐使用) 思路: 将链表反转,就是将每个表元的指针从向后变成向前,那我们可以遍历原始…

牛客题解 | 判断链表中是否有环

牛客题库题解题目 题目链接 题目主要信息:给定一个链表的头节点,判断这个链表是否有环 环形链表如下所示:举一反三: 学习完本题的思路你可以解决如下题目: BM4.合并有序链表 BM5.合并k个已排序的链表 BM7.链表中环的入口节点 BM8.链表中倒数最后k个节点 BM9.删除链表的倒数…