bzoj3442学习小组

题意:

共有n个学生,m个学习小组,每个学生只愿意参加其中的一些学习小组,且一个学生最多参加k个学习小组。每个学生参加学习小组财务处都收一定的手续费,不同的学习小组有不同的手续费。若有a个学生参加第i个学习小组,财务处支付奖励Ci*a^2元。在参与学生(而不是每个学习小组的人数总和)尽量多的情况下,求财务处最少要支出多少钱。

题解:

s连n个学生,流量为k,费用为0。每个学生向喜欢的小组的连边,流量为1,费用为手续费的相反数。每个小组向t连边,它的费用与流量的平方成正比的边,需要把它拆成k条流量为1,费用为1*ci、3*ci…(2*k-1)的边。本题的难点是要参与学生尽量多,所以我们需要每个学生至少参加一个组,因此每个学生再向t连一条流量为k-1,费用为0的边,就可以了。

代码:

 1 #include <cstdio>
 2 #include <algorithm>
 3 #include <cstring>
 4 #include <queue>
 5 #define inc(i,j,k) for(int i=j;i<=k;i++)
 6 #define visit(i,j) for(int i=g[j];i!=-1;i=es[i].n)
 7 #define INF 0x3fffffff
 8 using namespace std;
 9
10 struct e{int f,t,c,w,n;}; e es[1000000]; int ess,g[400];
11 void pe(int f,int t,int c,int w){
12     es[++ess]=(e){f,t,c,w,g[f]}; g[f]=ess; es[++ess]=(e){t,f,0,-w,g[t]}; g[t]=ess;
13 }
14 void init(){ess=-1; memset(g,-1,sizeof(g));}
15 int d[400],fr[400]; queue <int> q; bool inq[400],vis[400];
16 bool spfa(int s,int t){
17     while(! q.empty())q.pop(); memset(inq,0,sizeof(inq)); memset(vis,0,sizeof(vis));
18     inq[s]=1; d[s]=0; vis[s]=1; q.push(s);
19     while(! q.empty()){
20         int x=q.front(); q.pop(); inq[x]=0;
21         visit(i,x)if(es[i].c&&(! vis[es[i].t]||d[es[i].t]>d[x]+es[i].w)){
22             d[es[i].t]=d[x]+es[i].w; vis[es[i].t]=1; fr[es[i].t]=i;
23             if(! inq[es[i].t])inq[es[i].t]=1,q.push(es[i].t);
24         }
25     }
26     if(! vis[t])return 0;else return 1;
27 }
28 int advanced(int s,int t){
29     int a=INF; for(int i=t;i!=s;i=es[fr[i]].f)a=min(a,es[fr[i]].c);
30     int cost=0; for(int i=t;i!=s;i=es[fr[i]].f)es[fr[i]].c-=a,es[fr[i]^1].c+=a,cost+=(es[fr[i]].w*a);
31     return cost;
32 }
33 int maxflowmincost(int s,int t){
34     int cost=0; while(spfa(s,t))
35     cost+=advanced(s,t); return cost;
36 }
37 int n,m,k,s,t,a1[400]; char a3[400];
38 int main(){
39     //freopen("test.txt","r",stdin);
40     scanf("%d%d%d",&n,&m,&k); s=0; t=n+m+1; init(); inc(i,1,n)pe(s,i,k,0),pe(i,t,k-1,0);
41     inc(i,n+1,n+m){int a2; scanf("%d",&a2); inc(j,1,n)pe(i,t,1,(j*2-1)*a2);}
42     inc(i,1,m)scanf("%d",&a1[i]); inc(i,1,n){
43         scanf("%s",a3); inc(j,1,m){if(a3[j-1]==‘1‘)pe(i,n+j,1,-a1[j]);}
44     }
45     printf("%d",maxflowmincost(s,t));
46     return 0;
47 }

20160418

时间: 2024-08-08 09:38:17

bzoj3442学习小组的相关文章

bzoj3442 学习小组

目前处于迷之TLE状态 3442: 学习小组 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 200  Solved: 87 Description [背景] 坑校准备鼓励学生参加学习小组. [描述] 共有n个学生,m个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学生考虑,规定一个学生最多参加k个学习小组.财务处的大叔就没那么好了,他想尽量多收钱,因为每个学生参加学习小组都要交一定的手续费,不同的学习小组有不同的手续费.

【bzoj3442】学习小组 费用流

原文地址:http://www.cnblogs.com/GXZlegend/p/6809670.html 题目描述 [背景] 坑校准备鼓励学生参加学习小组. [描述] 共有n个学生,m个学习小组,每个学生有一定的喜好,只愿意参加其中的一些学习小组,但是校领导为学生考虑,规定一个学生最多参加k个学习小组.财务处的大叔就没那么好了,他想尽量多收钱,因为每个学生参加学习小组都要交一定的手续费,不同的学习小组有不同的手续费.然而,事与愿违,校领导又决定对学习小组组织者进行奖励,若有a个学生参加第i个学习

怎样增加Dave 英语学习小组

一.     增加小组 英语对IT 是非常重要的,但非常多人都不能坚持去学习,Dave 英语学习小组成立与已经超过半年,如今进行扩招.欢迎想提高英语,而且能够坚持每天学习的人,增加Dave 的小组.并坚持每天学习. 要求: (1)  从增加小组当天開始,计算打卡率. (2)   打卡率低于85%的,会被剔出小组,须要又一次增加. (3)  能够安装手机client.利用上下班的零碎时间来学习. (4)  每天学习英语时间控制在1小时左右. 注冊扇贝帐号: http://www.shanbay.c

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

如何组织好一个学习小组 引言 学习小组做的很多,成功的很少,如何做好一个学习小组,需要投入很多心思,比如选择学习内容,是否是大家感兴趣的:大家的时间问题:如何能保证大家学有所成-.但我们还是做了,这里给您展示我们学习小组的进展情况. 背景 学习小组从上周成立(和党的生日一天吧),本期学习内容是<C#图解教程>,学习的主力是4个实习生,及公司的测试经理(因测试经理没有开发经验,所以从基础做起吧),测试经理担任学习小组的组长.由于考虑到比较基础,每个人分2-3章,所以总计分配了10章内容.并让大家

Django学习小组出品:一起来做一个简单的Blog第一周文档(教程)

本节是 django blog 项目的开篇,是 django 学习小组的集体学习成果.django学习小组是由我发起的一个促进 django 新手互相学习.互相帮助的组织.小组在一边学习 django 的同时将一起完成三个项目: 一个简单django blog,用于发布小组每周的学习和开发文档 django中国社区,为国内的 django 开发者们提供一个长期维护的 django 社区,聚集全国的 django 开发者到这个社区上来 django 问答社区, 类似于segmentfault 和

BZOJ 3442 学习小组 费用流

题目大意:给出学生的数目和学习小组的数目,学生参加小组需要交纳费用,每个小组会支出C[i]*cnt[i]^2.每个学生可以参加k个小组,问最多的学生参加时,最小支出费用. 思路:如果不算后面那个什么鬼的条件的话,见图十分显然. S->每个学生 f:k,c:0 每个学生->每个学习小组 f:1,c:-F[i] 每个学习小组->T f:1,c:1 * C[i],3 * C[i],5 * C[i],7 * C[i],...... 后面的条件其实是说,每个学生的k次机会不一定全用光,但是所有人都

20175212童皓桢 学习小组结对声明

20175212童皓桢 学习小组结对声明 小组成员 20175212 童皓桢 20175227 张雪莹 小组合照 感想 结对编程并不适用众所周知的短板效应,而是相反的,程序的质量取决于水平较高的那一方,因此结对益处极大.再者,无论是什么科目,什么方向的学习,正所谓男女搭配,干活不累,抱团取暖,学到天黑,良好的搭档能够提供的不仅仅是表面上的督促或者讨论,更甚带来的是一种氛围,一种习惯,一种可能贯穿你一生的思路和思考方法.短期目标通过结对学习,(对Java的学习理解提高到一个新的层次! 原文地址:h

结对学习小组

结对学习小组 小组成员 结对同学20175212童皓桢 本人学号20175227张雪莹 小组合照 感想 结对学习是为了达到更好的学习效果,在学习过程中,互帮互助,互相发现逻辑上的错误,讨论纠正后提高思考问题.发表观点.讨论磨合的能力:我们一个踏实,一个思维活跃,相信在以后的Java学习过程中,能学得更好 原文地址:https://www.cnblogs.com/zxy20175227/p/10590337.html

如何管理好合作学习小组的晚自习课

实施问题导学教学模式以后,学生的课堂学习状态发生了很大的变化.主动发言的学生越来越多,学生之间的互动明显增加,课堂气氛更加活跃.所有这一切,正是老师所期待的课堂学习状态.但如果将这种学习状态迁移到晚自习课(或平时的自习课),情况就不是预料中的那种状态了.近期部分家长以及科任都对晚自习的纪律抱怨不止,担心晚自习的不合理的合作学习会影响学生的学习效率.主要表现在以下三个方面:现象1:少数学生过分依赖小组合作学习,喜欢不劳而获,拿着练习直接问同伴给答案:现象2:个人没有任何思考就直接求助于同伴.现象3