当前位置: 首页 > 编程日记 > 正文

bzoj3442 学习小组

目前处于迷之TLE状态

-----6.21更新 已AC

3442: 学习小组

Time Limit: 5 Sec  Memory Limit: 128 MB
Submit: 200  Solved: 87

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。

HINT

Source

By lll6924 at “冬令营后竞速放松赛”

同一门课报的人数不同,费用也会变化,所以需要“拆边”,从小组结点向汇点连n条边,费用分别为第1、2、3....n个人报名的费用,容量均为1

参与同学要尽可能多,但每个同学不一定要报满,所以从每个学生结点向汇点连k-1条边(至少报1项),费用均为0

此处为第一版。更新版本见更下方

 1 /*by SilverN*/
 2 #include<iostream>
 3 #include<algorithm>
 4 #include<cstring>
 5 #include<cstdio>
 6 #include<cmath>
 7 #include<queue>
 8 using namespace std;
 9 const int INF=100000000;
10 const int mxn=150;
11 int n,m,k;
12 int c[mxn];
13 int f[mxn];
14 int ans=0;
15 //net
16 struct edge{
17     int from,to,nx,v,c;
18 }e[mxn*500];
19 int s,t;
20 int cnt=1;
21 int hd[mxn],dis[mxn],pr[mxn];
22 bool inqu[mxn];
23 //
24 void add_edge(int u,int t,int v,int c){
25     e[++cnt]=(edge){u,t,hd[u],v,c};hd[u]=cnt;
26     e[++cnt]=(edge){t,u,hd[t],0,-c};hd[t]=cnt;
27     return ;
28 } 
29 bool SPFA(){
30     int i,j;
31     queue<int>q;
32     memset(inqu,false,sizeof(inqu));
33     for(i=0;i<=t;i++)dis[i]=INF;
34     dis[s]=0;
35     q.push(s);
36     inqu[s]=true;
37     while(!q.empty()){
38         int u=q.front();
39         inqu[u]=false;
40         q.pop();
41         for(i=hd[u];i;i=e[i].nx){
42             int v=e[i].to;
43             if(e[i].v && dis[u]+e[i].c<dis[v]){
44                 dis[v]=dis[u]+e[i].c;
45                 pr[v]=i;
46                 if(!inqu[v]){
47                     inqu[v]=true;
48                     q.push(v);
49                 }
50             }
51         }
52     }
53     return dis[t]!=INF;
54 }
55 void mcf(){
56     int i,j;
57     while(SPFA()){
58         int tmp=INF;
59         for(i=pr[t];i;i=pr[e[i].from])
60             tmp=min(tmp,e[i].v);
61         ans+=tmp*dis[t];
62         for(i=pr[t];i;i=pr[e[i].from]){
63             e[i].v-=tmp;
64             e[i^1].v+=tmp;
65         }
66     }
67     return;
68 }
69 int main(){
70     scanf("%d%d%d",&n,&m,&k);
71     int i,j;
72     for(i=1;i<=m;i++)scanf("%d",&c[i]);
73     for(i=1;i<=m;i++)scanf("%d",&f[i]);
74     char ch[100];
75     for(i=1;i<=n;i++){
76         scanf("%s",ch);
77         for(j=1;j<=m;j++){
78             if(ch[j-1]=='1') add_edge(i,j+n,1,0);
79         }
80     }
81     s=0;t=n+m+1;
82     for(i=1;i<=n;i++){
83         add_edge(s,i,k,0);
84         add_edge(i,t,k-1,0);//留出空边(并不是所有人都要排满课 )
85     }
86     for(i=1;i<=m;i++)
87       for(j=1;j<=n;j++){
88           add_edge(i+n,t,1,(2*j-1)*c[i]-f[i]);
89         //拆边,每多一个人报课,支出增长 
90       }
91     mcf();
92     printf("%d\n",ans);
93     return 0;
94 }

AC

各种缩小数组范围,加上inline和手动read,甚至用上了HK_reporter玄学加成,仍然TLE

最后的最后,FXXK,发现原来是数组开小了

  1 /*by SilverN*/
  2 #include<iostream>
  3 #include<algorithm>
  4 #include<cstring>
  5 #include<cstdio>
  6 #include<cmath>
  7 #include<queue>
  8 
  9 #define HK_reporter main
 10 using namespace std;
 11 const int INF=100000000;
 12 const int mxn=320;
 13 int n,m,k;
 14 int c[mxn];
 15 int f[mxn];
 16 int ans=0;
 17 //net
 18 struct edge{
 19     int from,to,nx,v,c;
 20 }e[mxn*400];
 21 int s,t;
 22 int cnt=1;
 23 int hd[mxn],dis[mxn],pr[mxn];
 24 bool inqu[mxn];
 25 //
 26 inline int read(){
 27     int x=0;char ch=getchar();
 28     while(ch<'0' ||ch>'9')ch=getchar();
 29     while(ch>='0' && ch<='9'){x=x*10+ch-'0';ch=getchar();}
 30     return x;
 31 }
 32 inline void add_edge(int u,int t,int v,int c){
 33     e[++cnt]=(edge){u,t,hd[u],v,c};hd[u]=cnt;
 34     e[++cnt]=(edge){t,u,hd[t],0,-c};hd[t]=cnt;
 35     return ;
 36 } 
 37 bool SPFA(){
 38     int i;
 39     queue<int>q;
 40     memset(inqu,false,sizeof(inqu));
 41     for(i=0;i<=t;i++)dis[i]=INF;
 42     dis[s]=0;
 43     q.push(s);
 44     inqu[s]=true;
 45     while(!q.empty()){
 46         int u=q.front();
 47         inqu[u]=false;
 48         q.pop();
 49         for(i=hd[u];i;i=e[i].nx){
 50             int v=e[i].to;
 51             if(e[i].v && dis[u]+e[i].c<dis[v]){
 52                 dis[v]=dis[u]+e[i].c;
 53                 pr[v]=i;
 54                 if(!inqu[v]){
 55                     inqu[v]=true;
 56                     q.push(v);
 57                 }
 58             }
 59         }
 60     }
 61     return dis[t]!=INF;
 62 }
 63 void mcf(){
 64     int i,j;
 65     while(SPFA()){
 66         int tmp=INF;
 67         for(i=pr[t];i;i=pr[e[i].from])
 68             tmp=min(tmp,e[i].v);
 69         ans+=tmp*dis[t];
 70         for(i=pr[t];i;i=pr[e[i].from]){
 71             e[i].v-=tmp;
 72             e[i^1].v+=tmp;
 73         }
 74     }
 75     return;
 76 }
 77 int HK_reporter(){
 78     n=read();m=read();k=read();
 79     int i,j;
 80     for(i=1;i<=m;i++)c[i]=read();
 81     for(i=1;i<=m;i++)f[i]=read();
 82     char ch[100];
 83     for(i=1;i<=n;i++){
 84         scanf("%s",ch+1);
 85         for(j=1;j<=m;j++){
 86             if(ch[j]=='1') add_edge(i,j+n,1,0);
 87         }
 88     }
 89     s=0;t=n+m+1;
 90     for(i=1;i<=n;i++){
 91         add_edge(s,i,k,0);
 92         add_edge(i,t,k-1,0);//留出空边(并不是所有人都要排满课 )
 93     }
 94     for(i=1;i<=m;i++)
 95       for(j=1;j<=n;j++){
 96           add_edge(i+n,t,1,(2*j-1)*c[i]-f[i]);
 97         //拆边,每多一个人报课,支出增长 
 98       }
 99     mcf();
100     printf("%d\n",ans);
101     return 0;
102 }

转载于:https://www.cnblogs.com/SilverNebula/p/5602240.html

相关文章:

C语言经典著作导读

本人不是卖书的&#xff0c;我也不会给出任何购书链接&#xff0c;只是给C语言学习者推荐一条学习的方向。如果你喜欢看电子书网上很多&#xff0c;如果你喜欢纸质那么就买吧&#xff0c;经典的书值得收藏&#xff0c;是对版权的尊重&#xff01; 基础篇 1.《写给大家看的C语言…

针对2013年B题碎纸片拼接问题(附件一、附件二)

题目链接&#xff1a;https://blog.csdn.net/CSDN___CSDN/article/details/82051821 http://www.shumo.com/wiki/doku.php?id2013_%E5%B9%B4%E5%85%A8%E5%9B%BD%E5%A4%A7%E5%AD%A6%E7%94%9F%E6%95%B0%E5%AD%A6%E5%BB%BA%E6%A8%A1%E7%AB%9E%E8%B5%9B_cumcm_%E8%AF%95%E9%A2%98…

什么是类型别名?什么是潜在类型?

2019独角兽企业重金招聘Python工程师标准>>> 别名类型 在Go语言里&#xff0c;可以用type声明自定义的各种类型。在这些自定义的类型中&#xff0c;有一种被叫做别名类型。 举个例子&#xff1a; type MyString string这句代码的意思是&#xff1a;MyString是strin…

Linux网络编程必看书籍推荐

首先要说讲述计算机网络和TCP/IP的书很多。 先要学习网络知识才谈得上编程 讲述计算机网络的最经典的当属Andrew S&#xff0e;Tanenbaum的《计算机网络》第五版&#xff0c;这本书难易适中。 《计算机网络&#xff08;第5版&#xff09;》是国内外使用最广泛、最权威的计算机…

5个最佳的Android测试框架

2019独角兽企业重金招聘Python工程师标准>>> 谷歌的Android生态系统正在不断地迅速扩张。有证据表明&#xff0c;新的移动OEM正在攻陷世界的每一个角落&#xff0c;不同的屏幕尺寸、ROM /固件、芯片组以及等等等等&#xff0c;层出不穷。于是乎&#xff0c;对于Andr…

【CTF】实验吧 凯撒变异

通过分析可以知道前四个“afZ_”四个的ASCII码值与“flag”的ASCII码值依次相差5&#xff0c;6&#xff0c;7&#xff0c;8。 #include <stdio.h> #include <string.h> int main () {char str[40]"afZ_r9VYfScOeO_UL^RWUc";int i0,j5;while(i<strlen…

ant design pro (八)构建和发布

一、概述 原文地址&#xff1a;https://pro.ant.design/docs/deploy-cn 二、详细 2.1、构建 当项目开发完毕&#xff0c;只需要运行一行命令就可以打包你的应用&#xff1a; npm run build 由于 Ant Design Pro 底层使用的 roadhog 工具&#xff0c;已经将复杂的流程封装完毕&a…

Linux进程间通信--进程,信号,管道,消息队列,信号量,共享内存

Linux进程间通信--进程&#xff0c;信号&#xff0c;管道&#xff0c;消息队列&#xff0c;信号量&#xff0c;共享内存 参考&#xff1a;《linux编程从入门到精通》,《Linux C程序设计大全》,《unix环境高级编程》 参考&#xff1a;C和指针学习 说明&#xff1a;本文非常的长…

PgSQL · 实战经验 · 如何预测Freeze IO风暴

背景和原理 有没有被突发的IO惊到过&#xff0c;有没有见到过大量的autovacuum for prevent wrap。 PostgreSQL 的版本冻结是一个比较蛋疼的事情&#xff0c;为什么要做版本冻结呢&#xff1f; 因为PG的版本号是uint32的&#xff0c;是重复使用的&#xff0c;所以每隔大约20亿…

【CTF】实验吧 传统知识+古典密码

对照顺序写下&#xff1a; 根据对应的干支得到 28 30 23 8 17 10 16 30 甲子 所有的数加60 得到 88 90 83 68 77 70 76 90 找到ASCII码对照表可得到XZSDMFLZ 题干中提到古典密码&#xff08;常用的就是栅栏密码和凯撒密码&#xff09; 栅栏密码&#xff08;两栏&#…

NSSize 尺寸

前言 结构体&#xff0c;这个结构体用来表示事物的宽度和高度。typedef CGSize NSSize;struct CGSize {CGFloat width;CGFloat height; };typedef struct CGSize CGSize; 1、NSSize 结构体变量的创建与调用 // NSSize 结构体变量的创建与赋值// 先定义变量&#xff0c;再赋值 N…

Android中对Log日志文件的分析[转]

一&#xff0c;Bug出现了&#xff0c; 需要“干掉”它 bug一听挺吓人的&#xff0c;但是只要你懂了&#xff0c;android里的bug是很好解决的&#xff0c;因为android里提供了LOG机制&#xff0c;具体的底层代码&#xff0c;以后在来分析&#xff0c;只要你会看bug&#xff0c;a…

Unix下C程序内存泄漏检测工具Valgrind安装与使用

Valgrind是一款用于内存调试、内存泄漏检测以及性能分析的软件开发工具。 Valgrind的最初作者是Julian Seward&#xff0c;他于2006年由于在开发Valgrind上的工作获得了第二届Google-OReilly开源代码奖。 Valgrind遵守GNU通用公共许可证条款&#xff0c;是一款自由软件。 官网…

【CTF】实验吧 robomunication

用audacity软件&#xff0c;猜测是摩斯密码 听到的都是“bi”或者“bu”&#xff0c;这里用b代表“bi”&#xff0c;“p”代表“bu” bbbb b bpbb bpbb ppp bpp bbbb bp p bb bbb p bbbb b pbp b pbpp bb p bb bbb (p b bb) ppp ppp bppb pbbb b b bppb 打括号那里显得较分散一…

Mac原生Terminal快速登录ssh

1. 创建rsa key 在终端中输入以下命令&#xff1a; ssh-keygen -t rsa完成之后可以在~/.ssh目录下找到公钥和私钥 如果你与我一样有使用gitlab&#xff0c;那么这个秘钥应该已经存在了&#xff0c;所以就不用重新建立了。 2.上传公钥到服务器 有教程会说&#xff0c;用scp或者类…

Java开发环境的搭建以及使用eclipse从头一步步创建java项目

原文&#xff1a;出自本人的Linux博客http://blog.csdn.net/unix21/article/details/18813173 一、Java 开发环境的搭建 这里主要说windows环境下怎么配置Java环境。如果是Linux环境参考本博客另一篇文章即可&#xff1a;Linux环境安装卸载JDK1.首先安装JDK java的SDK简称JDK。…

全球首届APMCon,带你给“应用性能”把把脉

前段时间&#xff0c;美国苹果公司应用程序购买商店和手机等一系列应用因技术故障中断服务&#xff0c;持续了约两个半小时。故障发生后&#xff0c;世界多地苹果用户纷纷吐槽无法购买和更新手机应用、无法备份等。其实&#xff0c;这不是苹果公司在线服务第一次掉线&#xff0…

【CTF】实验吧 The Flash-14

标题的提示是&#xff1a;闪电侠的第十四集用到的加密方式&#xff08;看来写CTF题要无所不知&#xff0c;不然咋能想到是一部剧&#xff09; 根据两两一组将数据分类 54 43 32 52 22 44 55 34 22 51 52 22 44 34 22 23 11 34 12 按照上表的对应关系可以得到…

XML 标签 首字母转换为大写

2019独角兽企业重金招聘Python工程师标准>>> public static String xmlTagCapitalize(String xmlStr) {String regex "<(/*[A-Za-z])>";regex "<([^>]*)>";Matcher matcher Pattern.compile(regex).matcher(xmlStr);StringBu…

简析 .NET Core 构成体系

简析 .NET Core 构成体系 Roslyn 编译器RyuJIT 编译器CoreCLR & CoreRTCoreFX(.NET Core Libraries).NET Core 代码开发、部署、运行过程总结前文介绍了.NET Core 在整个.NET 平台所处的地位&#xff0c;以及与.NET Framework的关系(原文链接)&#xff0c;本文将详细介绍.N…

【CTF】实验吧 奇怪的短信

和实验吧 The Flash-14有些类似&#xff0c;总共的数字数目是偶数&#xff0c;所以两两分开&#xff0c;题干中的“短信”是提示&#xff0c;观察两两分组的第二个数字没有超过四的&#xff0c;可以想到手机上的九键 例如第一组数&#xff1a;33 对应的是F&#xff0c;最后全部…

mybatis结合log4j打印SQL日志

mybatis结合log4j打印SQL日志1.Maven引用jar包 默认的mybatis不能打印出SQL日志&#xff0c;不便于查看调试&#xff0c;需要结合log4jdbc-log4j2就可以完整的输入SQL的调试信息。 pom.xml 配置maven&#xff0c;注意以下3个都需要<dependency><groupId>org.bgee.l…

EOS Chain/Wallet RPC API的PHP开发包

2019独角兽企业重金招聘Python工程师标准>>> 介绍一个EOS Chain/Wallet RPC API的PHP开发包。 开始 你可以查看EOS的RPC API参考&#xff0c;但要注意缺少一些较新的方法。Wallet RPC API实现EOS v1.1.0 of RPC API reference。此外&#xff0c;这些文档中的一些示例…

深入浅出理解Paxos算法

Paxos算法是莱斯利兰伯特&#xff08;英语&#xff1a;Leslie Lamport&#xff0c;LaTeX中的「La」&#xff09;于1990年提出的一种基于消息传递且具有高度容错特性的一致性算法。 Paxos算法一开始非常难以理解&#xff0c;但是一旦理解其实也并不难&#xff0c;之所以难理解其…

显示界面的普通仓库

实际脚本如下 procedure xianshi_PTCK(Npc: TNormNpc; Player: TPlayObject);procedure CWPRPTCK_QWP(Npc: TNormNpc; Player: TPlayObject; Args: TArgs); beginplayer.TakebackStorageItem(Args.Int[0]);cangku.xianshi_PTCK(npc,player); end; procedure xianshi_PTCK(Np…

【CTF】实验吧 围在栅栏中的爱

对摩斯密码进行解码&#xff1a;kiqlwtfcqgnsoo QWE是键盘上的前三个&#xff0c;ABC是26个字母的前三个。所以&#xff0c;二者有这样的对应关系。 #include <stdio.h> #include <string.h> int main () {char zc[]"abcdefghijklmnopqrstuvwxyz"; cha…

nginx tomcat https

1.首先确保机器上安装了openssl和openssl-devel #yum install openssl #yum install openssl-devel2. server {listen 443 ssl;server_name vota.swmmotors.com.cn;ssl_certificate cert/vota.swmmotors.com.cn_bundle.crt; #当前conf/目录下ssl_certificate_…

Spring4实战学习笔记

《Spring4实战 第4版》2016年4月新出版的&#xff0c;之前的第三版看起来还是不错的&#xff0c;所以看到新版就直接买下来。 英文版源码地址&#xff1a;Spring in Action, Fourth Edition Covers Spring 4 1.IOC装配Bean 参考【Spring实战4 2.2】&#xff0c;作者提倡无XML…

vmstat 命令

2019独角兽企业重金招聘Python工程师标准>>> 1.用法 vmstat [-a] [-n] [-S unit] [delay [ count]] vmstat [-s] [-n] [-S unit] vmstat [-m] [-n] [delay [ count]] vmstat [-d] [-n] [delay [ count]] vmstat [-p disk partition] [-n] [delay [ count]] vmstat […

【CTF】实验吧 疑惑的汉字

考察的是当铺密码&#xff1a; 王夫 井工 夫口 由中人 井中 夫夫 由中大&#xff1a;67 84 70 123 82 77 125 当铺密码就是一种将中文和数字进行转化的密码&#xff0c;算法相当简单:当前汉字有多少笔画出头&#xff0c;就是转化成数字几。