洛谷——P2417 课程
P2417 课程
裸地匈牙利算法,
贪心的不断匹配,若没匹配,则匹配;反之,判断与之匹配的点能否在找另一个点匹配,若能,抢多这个点与之匹配
时间复杂度O(n\times m)
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> #define N 2000000 using namespace std; struct node{ int to,next; }e[N]; int t,head[N],tot,p,n,match[N],dfn[N],ans; void add(int u,int v){ e[++tot].to=v,e[tot].next=head[u],head[u]=tot; } bool dfs(int u,int t){ for(int i=head[u];i;i=e[i].next){ int v=e[i].to; if(dfn[v]!=t){ dfn[v]=t; if(!match[v]||dfs(match[v],t)){ match[v]=u;return true; } } } return false; } int main() { scanf("%d",&t); while(t--){ memset(head,0,sizeof(head)); memset(match,0,sizeof(match)); memset(dfn,0,sizeof(dfn)); tot=ans=0; scanf("%d%d",&p,&n); for(int m,v,i=1;i<=p;i++){ scanf("%d",&m); for(int j=1;j<=m;j++){ scanf("%d",&v),add(v,i); } } for(int i=1;i<=n;i++) if(dfs(i,i)) ++ans; if(ans>=p) printf("YES\n"); else printf("NO\n"); } return 0; }
P2071 座位安排
模板,又是模板,建图方式有一点儿不同,因为每一排有两个座位
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> #define N 2000000 using namespace std; struct node { int to,next; } e[N]; int t,head[N],tot,p,n,match[N],dfn[N],ans; void add(int u,int v) { e[++tot].to=v,e[tot].next=head[u],head[u]=tot; } bool dfs(int u,int t) { for(int i=head[u]; i; i=e[i].next) { int v=e[i].to; if(dfn[v]!=t) { dfn[v]=t; if(!match[v]||dfs(match[v],t)) { match[v]=u; return true; } } } return false; } int main() { memset(head,0,sizeof(head)); memset(match,0,sizeof(match)); memset(dfn,0,sizeof(dfn)); tot=ans=0; scanf("%d",&n); for(int x,y,i=1; i<=n*2; i++) { scanf("%d%d",&x,&y); add(i,x),add(i,x+n),add(i,y),add(i,y+n); } for(int i=1; i<=n*2; i++) if(dfs(i,i)) ++ans; printf("%d\n",ans); return 0; }
P1894 [USACO4.2]完美的牛栏The Perfect Stall
裸题
#include<iostream> #include<cstdio> #include<algorithm> #include<cstring> #define N 2000000 using namespace std; struct node { int to,next; } e[N]; int t,head[N],tot,m,n,match[N],dfn[N],ans; void add(int u,int v) { e[++tot].to=v,e[tot].next=head[u],head[u]=tot; } bool dfs(int u,int t) { for(int i=head[u]; i; i=e[i].next) { int v=e[i].to; if(dfn[v]!=t) { dfn[v]=t; if(!match[v]||dfs(match[v],t)) { match[v]=u; return true; } } } return false; } int main() { memset(head,0,sizeof(head)); memset(match,0,sizeof(match)); memset(dfn,0,sizeof(dfn)); tot=ans=0; scanf("%d%d",&n,&m); for(int v,x,i=1; i<=n; i++) { scanf("%d",&x); for(int j=1;j<=x;j++) { scanf("%d",&v); add(i,v); } } for(int i=1; i<=n; i++) if(dfs(i,i)) ++ans; printf("%d\n",ans); return 0; }
博主蒟蒻,若有出错的地方,敬请指出。
如有侵犯您版权的地方,请快速联系我,我会撤回本博文。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
· 个人数据保全计划:从印象笔记迁移到joplin
· Vue3.5常用特性整理
· 重拾 SSH:从基础到安全加固
· 为什么UNIX使用init进程启动其他进程?