第一问最小割,第二问:

设du[i]表示i点的度数,则要最小化$\frac{|1集合的du[i]之和-2集合的du[i]之和|}{2}$,

压位01背包即可。

#include<cstdio>
#include<bitset>
using namespace std;
const int N=40010,inf=~0U>>2;
struct edge{int t,f;edge*nxt,*pair;}*g[N],*d[N],pool[240000],*cur=pool;
int Case,n,m,cnt,i,x,y,S,T,h[N],gap[N],maxflow,du[N],ans;bitset<19910>f;
inline int abs(int x){return x>0?x:-x;}
inline int min(int x,int y){return x<y?x:y;}
inline void add(int s,int t,int f){edge*p=cur++;p->t=t;p->f=f;p->nxt=g[s];g[s]=p;p=cur++;p->t=s;p->f=0;p->nxt=g[t];g[t]=p;g[s]->pair=g[t];g[t]->pair=g[s];
}
int sap(int v,int flow){if(v==T)return flow;int rec=0;for(edge*p=d[v];p;p=p->nxt)if(h[v]==h[p->t]+1&&p->f){int ret=sap(p->t,min(flow-rec,p->f));p->f-=ret;p->pair->f+=ret;d[v]=p;if((rec+=ret)==flow)return flow;}if(!(--gap[h[v]]))h[S]=T;gap[++h[v]]++;d[v]=g[v];return rec;
}
int main(){for(scanf("%d",&Case);Case--;printf("%d\n",ans)){scanf("%d%d",&n,&m),S=n+m+m+1,T=S+1,cnt=n;for(i=1;i<=m;i++){scanf("%d%d",&x,&y);du[x]++,du[y]++;add(S,++cnt,1),add(++cnt,T,1);add(cnt-1,x,inf),add(x,cnt,inf);add(cnt-1,y,inf),add(y,cnt,inf);}add(S,1,inf),add(2,T,inf);for(gap[maxflow=0]=T,i=1;i<=T;i++)d[i]=g[i];while(h[S]<T)maxflow+=sap(S,inf);printf("%d ",m*2-maxflow);for(cur=pool,i=0;i<=T;i++)g[i]=d[i]=NULL,h[i]=gap[i]=0;for(f.reset(),f[0]=1,i=3;i<=n;i++)f|=f<<du[i];for(ans=inf,i=0;i<=m;i++)if(f[i])ans=min(ans,abs(du[1]+i-m));for(i=1;i<=n;i++)du[i]=0;}return 0;
}

  

转载于:https://www.cnblogs.com/clrs97/p/4608833.html

BZOJ4155 : [Ipsc2015]Humble Captains相关推荐

  1. BZOJ 4155 Humble Captains

    目录 BZOJ 4155 Humble Captains 题意 题解 Code BZOJ 4155 Humble Captains 题目传送门1 题意 每天下午放学时都有n个zky冲出教室去搞基.搞基 ...

  2. usaco ★Humble Numbers 丑数

    ★Humble Numbers 丑数 对于一给定的素数集合 S = {p1, p2, ..., pK}, 来考虑那些质因数全部属于 S 的数的集合.这个集合包括,p1, p1p2, p1p1, 和 p ...

  3. 【HDOJ】1058 Humble Numbers

    简单题,注意打表,以及输出格式.这里使用了可变参数. 1 #include <stdio.h> 2 3 #define MAXNUM 5845 4 #define ANS 20000000 ...

  4. poj 2247 Humble Numbers

    Humble Numbers Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9453   Accepted: 4440 题目 ...

  5. A humble heart2019-11-09

    The vast universe can still work without anyone, facing the unknown with a humble heart.

  6. 丑数 Humble Numbers

    https://www.luogu.org/problemnew/show/P2723 题解: C++版本一 题解:STL+优化 /* *@Author: STZG *@Language: C++ * ...

  7. hdu 1058 Humble Numbers

    状态转移方程:F(n)=min(F(i)*2,F(j)*3,F(k)*5,F(m)*7)  (n>i,j,k,m) 特别的:i,j,k,m 只有在本项被选中后才移动 题目还要注意的一点是输出问题 ...

  8. HDU 1492 The number of divisors(约数) about Humble Numbers(数论,简单约数)

    The number of divisors(约数) about Humble Numbers Time Limit: 2000/1000 MS (Java/Others)    Memory Lim ...

  9. HDU1058 Humble Numbers

    题目:Humble Numbers humble number从1为"始祖",剩下的所有数,其实都是在此基础上乘以2,3,5,7演化出来的,代码主要语句:f[t]=min(2*f[ ...

最新文章

  1. iOS SwiftUI篇-3 排版布局layout
  2. 首款AI+智能工程头盔发布,小松(中国)与天远科技ICT战略签约成功举行
  3. 深圳6月23号活动《产品经理三分钟》报名开始啦!
  4. drf认证组件源码分析
  5. 计算机为什么启动二次才能打开,为什么电脑要2次重启才能启动显示器那
  6. 485 九针头_张元英安宥真还是孩子,手臂还有疫苗接种痕迹,九针头太吓人
  7. mysql group原理_MySQL Group By 实现原理分析
  8. Codeforces Round #736 (Div. 2)(B-C)
  9. 移动APP怎样保存用户password
  10. 内置对象和自定义对象的原型链
  11. 设计自己的基于Selenium 的自动化测试框架-Java版(2) - 定义自己的工作流程
  12. 右键 无响应_26个你需要学习的Firefox配置技巧,改进和加快浏览器响应速度
  13. 城市不透水面空间分析——以宁波为例
  14. android发送短信界面,android调用系统发送短信 和 已发送短信界面
  15. B站收藏 6.1w+!GitHub 标星 3.9k+!这门神课拯救了我薄弱的计算机基础
  16. 浅谈LCD液晶屏和LED屏,它们有什么不同之处
  17. C# 程序集(Assembly)
  18. Dcat-Admin自定义Excel数据导出
  19. 理解插值法(拉格朗日、牛顿插值法)
  20. STM32/GD32 Bootloader升级APP研究以及编程实现

热门文章

  1. C语言中:#define宏的正确使用
  2. 现实工程中常用到的C语言函数总结(不断更新)
  3. mysql二: 常用命令
  4. springmvc十八:RestfulCRUD增删改查小实战
  5. springmvc二: @RequestMapping
  6. python二十三:装饰器 ?
  7. 【自用】 Android Studio Gradle sync failed
  8. 读书笔记 effective c++ Item 49 理解new-handler的行为
  9. maven学习(中)- 私服nexus搭建
  10. python: 多线程实现的两种方式及让多条命令并发执行