Description

【背景】
坑校准备鼓励学生参加学习小组。
【描述】
共有n个学生,m个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学生考虑,规定一个学生最多参加k个学习小组。财务处的大叔就没那么好了,他想尽量多收钱,因为每个学生参加学习小组都要交一定的手续费,不同的学习小组有不同的手续费。然而,事与愿违,校领导又决定对学习小组组织者进行奖励,若有a个学生参加第i个学习小组,那么给这个学习小组组织者奖励Ci*a^2元。在参与学生(而不是每个学习小组的人数总和)尽量多的情况下,求财务处最少要支出多少钱(若为负数,则输出负数)(支出=总奖励费-总手续费)。

Input

输入有若干行,第一行有三个用空格隔开的正整数n、m、k。接下来的一行有m个正整数,表示每个Ci。第三行有m个正整数,表示参加每个学习小组需要交的手续费Fi。再接下来有一个n行m列的矩阵,表若第i行j列的数字是1,则表示第i个学生愿意参加第j个学习小组,若为0,则为不愿意。

Output

输出只有一个整数,为最小的支出。

Sample Input


3 3 1
1 2 3
3 2 1
111
111
111

Sample Output


-2
【样例解释】
参与学生最多为3,每个学生参加一个学习小组,若有两个学生参加第一个学习小组,一个学生参加第二个学习小组(一定要有人参加第二个学习小组),支出为-2,可以证明没有更优的方案了。
【数据范围与约定】
100%的数据,0<n≤100,0<m≤90,0<k≤m,0<Ci≤10,0<Fi≤100。
费用流建模题。。。
因为Ci*a^2不好处理,我们可以将其拆成费用为Ci、3Ci、5Ci、7Ci、(2n-1)Ci这N条边,由数列的基本知识可以证明这是对的。
因为要求参与的人数最多,我们可以先添加一条费用为-inf的有向边,最后再加回来。
之后的建模就简单了,见code吧。

#include<cstdio>
#include<cctype>
#include<queue>
#include<cmath>
#include<cstring>
#include<algorithm>
#define rep(i,s,t) for(int i=s;i<=t;i++)
#define dwn(i,s,t) for(int i=s;i>=t;i--)
#define ren for(int i=first[x];i!=-1;i=next[i])
using namespace std;
inline int read() {int x=0,f=1;char c=getchar();for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;for(;isdigit(c);c=getchar()) x=x*10+c-'0';return x*f;
}
typedef long long ll;
const int maxn=310;
const int maxm=200010;
const int inf=1e9;
struct ZKW {int n,m,s,t,first[maxn],next[maxm],vis[maxn],inq[maxn];ll cost,ans,d[maxn];struct Edge {int from,to,flow;ll cost;}edges[maxm];void init(int n) {this->n=n;m=0;memset(first,-1,sizeof(first));}void AddEdge(int u,int v,int w,ll c) {edges[m]=(Edge){u,v,w,c};next[m]=first[u];first[u]=m++;edges[m]=(Edge){v,u,0,-c};next[m]=first[v];first[v]=m++;}int Q[maxn];int BFS() {int l=0,r=0;rep(i,1,n) d[i]=1ll<<60,inq[i]=0;Q[r++]=t;d[t]=0;while(l!=r) {int x=Q[l++];if(l==maxn-1) l=0;inq[x]=0;ren {Edge& e=edges[i^1];if(e.flow&&d[e.from]>d[x]+e.cost) {d[e.from]=d[x]+e.cost;if(!inq[e.from]) {inq[e.from]=1,Q[r++]=e.from;if(r==maxn-1) r=0;}} }}rep(i,0,m-1) edges[i].cost+=d[edges[i].to]-d[edges[i].from];cost+=d[s];return cost<0;}int DFS(int x,int a) {if(x==t||!a) {ans+=a*cost;return a;}int f,flow=0;vis[x]=1;ren {Edge& e=edges[i];if(!e.cost&&e.flow&&!vis[e.to]&&(f=DFS(e.to,min(a,e.flow)))) {e.flow-=f;edges[i^1].flow+=f;flow+=f;a-=f;if(!a) break;}}return flow;}ll solve(int s,int t) {this->s=s;this->t=t;cost=ans=0;while(BFS()) do memset(vis,0,sizeof(vis));while(DFS(s,inf));return ans;}
}sol;
int c[maxn],f[maxn];
char s[maxn];
int main() {int n=read(),m=read(),k=read();rep(i,1,m) c[i]=read();rep(i,1,m) f[i]=read();int S=n+m+m+1,T=n+m+m+2;sol.init(T);rep(i,1,n) sol.AddEdge(S,i,1,-inf),sol.AddEdge(S,i,k-1,0);rep(i,1,m) {sol.AddEdge(i+n+m,T,n,-f[i]);rep(j,1,n) sol.AddEdge(i+n,i+n+m,1,c[i]*(j*2-1));}ll sum=0;rep(i,1,n) {int ok=0;scanf("%s",s+1);rep(j,1,m) if(s[j]=='1') sol.AddEdge(i,j+n,1,0),ok=1;if(ok) sum+=inf;}printf("%lld\n",sol.solve(S,T)+sum);return 0;
}

View Code

转载于:https://www.cnblogs.com/wzj-is-a-juruo/p/5284771.html

BZOJ3442: 学习小组相关推荐

  1. bzoj3442学习小组

    bzoj3442学习小组 题意: 共有n个学生,m个学习小组,每个学生只愿意参加其中的一些学习小组,且一个学生最多参加k个学习小组.每个学生参加学习小组财务处都收一定的手续费,不同的学习小组有不同的手 ...

  2. bzoj3442 学习小组

    目前处于迷之TLE状态 -----6.21更新 已AC 3442: 学习小组 Time Limit: 5 Sec  Memory Limit: 128 MB Submit: 200  Solved:  ...

  3. 【bzoj3442】学习小组 费用流

    原文地址:http://www.cnblogs.com/GXZlegend/p/6809670.html 题目描述 [背景] 坑校准备鼓励学生参加学习小组. [描述] 共有n个学生,m个学习小组,每个 ...

  4. 【原创】如何组织好一个学习小组

    如何组织好一个学习小组 引言 学习小组做的很多,成功的很少,如何做好一个学习小组,需要投入很多心思,比如选择学习内容,是否是大家感兴趣的:大家的时间问题:如何能保证大家学有所成-.但我们还是做了,这里 ...

  5. 知识图谱学习小组学习大纲

    (这是为北京知识学习小组第一期 kgbj1 准备的为期4周的学习大纲) 2016年6月3日 鲍捷 这个学习小组的目的,不是按教科书的定义去学习"知识图谱",更不是做研究.我们更多是 ...

  6. 【面试必备】通俗易懂的XGBoost、Transformer、BERT、水波网络原理解析 | 学习小组...

    在当今的人工智能时代,相信大部分人都会关注深度学习技术,但请千万不要忽视对传统机器学习技术的理解.实际上,真正去从事AI工作的时候就会发现,对传统机器学习的依赖还是巨大的.如逻辑回归.随机森林.GBD ...

  7. 如何加入Dave英语学习小组

    一.     加入小组 英语对IT 是非常重要的,但很多人都不能坚持去学习,Dave 英语学习小组成立与已经超过半年,现在进行扩招,欢迎想提高英语,并且能够坚持每天学习的人,加入Dave 的小组,并坚 ...

  8. 34个省市自治区排序_freeCodeCamp的1,000多个学习小组现已完全自治

    34个省市自治区排序 by Justin Sane 贾斯汀·桑恩(Justin Sane) freeCodeCamp的1,000多个学习小组现已完全自治 (freeCodeCamp's 1,000+ ...

  9. 怎样增加Dave 英语学习小组

    一.     增加小组 英语对IT 是非常重要的,但非常多人都不能坚持去学习,Dave 英语学习小组成立与已经超过半年,如今进行扩招.欢迎想提高英语,而且能够坚持每天学习的人,增加Dave 的小组.并 ...

最新文章

  1. pku1384---Piggy-Bank(动态规划)
  2. android 移除自己view,Android自定义View-带删除和搜索图标的EditText
  3. 【Linux 】使用 Shell 批量重命名文件名称
  4. 实战部署MySQL用户认证的Postfix邮件系统(3)
  5. 揭秘ThreadLocal
  6. 2027. 转换字符串的最少操作次数
  7. unity 烘焙参数 设置_Unity通用渲染管线(URP)系列(九)——点光源和聚光灯
  8. java正则替换数字_Java 正则表达式,替换图片名称,替换数字,和谐用语,复制文件...
  9. 消息中间件:ActiveMQ、RocketMQ、RabbitMQ、Kafka一些总结和区别
  10. Python3使用xpath爬取豆丁网文档
  11. IDEA jsp中文乱码
  12. 台式计算机键盘驱动,台式电脑键盘无法找到驱动, 为什么?
  13. PayPal如何提现人民币?PayPal提现到国内银行的最新教程!
  14. 技术管理必备之沟通机制
  15. html怎么直接修改,如何编辑运行HTML网页文件(HTML编辑工具使用介绍)
  16. ORACLE介质管理库MML
  17. 机器学习面试问题汇总
  18. 编译原理学习 一 什么是编译程序
  19. 分享给你——2017我学到的方法论
  20. 中国全屋智能行业市场前瞻与投资战略规划分析报告

热门文章

  1. 一张图带你看懂 ,web前端开发应该知道的HTML5六大趋势
  2. URI is not registered (Settings | Languages Frameworks | Schemas and DTDs)怎么解决?
  3. 客户端序列码生成_Django REST Framework教程(2): 序列化器介绍及开发基于函数视图的API...
  4. 编译ffmpeg出现 librtmp not found using pkg-config
  5. 将Tomcat集成到eclipse中并写出第一条web语句
  6. NYOJ-数独(dfs)
  7. spring 自动扫包代码放置的位置问题
  8. 理解saltstack 里cmd.run 配合onlyif和unless使用
  9. MyBatis源码解读之源码结构
  10. 彻底删除0KB顽固文件或文件夹的方法