题意:

给定n个人,分两天晚上去夜总会开派对,要求每天恰好有n/2个人去,且每人去的夜总会各不相同。

每个人对不同的晚上不同的夜总会有不同的满意度,求一个方案使得所有人的满意度之和最大。

夜总会数量=人的数量=n,2<=n<=20,且n是偶数。

0<=每一项满意度<=10^6。

时间限制2s,空间限制4MB。

题解:

在这题上卡了很久…

初看这题觉得是费用流…写完发现图建错了…

然后改成暴力枚举哪些人在第一天晚上去再跑费用流…

每个人只和对应晚上的夜总会连边,然后两天晚上的夜总会再连到一个辅助点,再连到汇…

就避免了跑出来的东西有两人在不同的晚上去同一个夜总会…

理所当然地超时了…

后来换成比较擅长这种图的zkw费用流…快了很多,但还是严重超时…

然后开始怀疑自己的做法…试图写DP…很快放弃了…

然后突然发现自己之前建图时傻掉了,枚举夜总会在哪个晚上有人就可以把图变成二分图…

于是改改改…改成KM…还是严重超时…大数据跑100s…

于是弃疗了…去膜拜Tourist的代码…结果发现就是KM…只不过是非递归的KM…

都是KM…差距就是这么大…

主要原因就是点是一个个加进二分图的,如果在最后跑KM,就完全没有用到子图的信息…

用非递归KM的话…一层层下去,冗余运算就减少了很多。

简单来说这题的做法就是:

枚举夜总会,一边向图中加点一边跑KM,然后就可以了…(CF评测机快,2s可过…

 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <cstdio>
#include <cstring>
#define mv(a,b) memcpy(a,b,(n<<2)+4)
inline int read()
{
int s = ; char c; while((c=getchar())<'0'||c>'9');
do{s=s*+c-'0';}while((c=getchar())>='0'&&c<='9');
return s;
}
const int N = , INF = 0x7f7f7f7f;
int n,n2,w1[N][N],w2[N][N],w[N][N],ans,tans,lx[N],ly[N],sl[N],lk[N],pat[N];
bool by[N];
void dfs(int nn,int d1,int d2)
{
if(nn>n){ if(ly[]>ans) ans = ly[]; return; }
int _lx[N],_ly[N],_lk[N],_a,i,cy,cx,ny;
for(int ch=;ch<;ch++)
{
if(d1==n2&&ch==) continue;
if(d2==n2&&ch==) continue;
mv(_lx,lx), mv(_ly,ly), mv(_lk,lk);
if(ch) mv(w[nn],w1[nn]); else mv(w[nn],w2[nn]);
memset(sl,0x7f,(n<<)+), memset(by,,n+);
cy = ; lk[] = nn;
while(lk[cy])
{
by[cy] = ; cx = lk[cy]; int tmp = INF;
for(i=;i<=n;i++)
if(!by[i])
{
int t = -lx[cx]-ly[i]-w[cx][i];
if(t<sl[i]) sl[i] = t, pat[i] = cy;
if(sl[i]<tmp) tmp = sl[i], ny = i;
}
for(i=;i<=n;i++)
{
if(by[i]) lx[lk[i]] += tmp, ly[i] -= tmp;
else sl[i] -= tmp;
}
cy = ny;
}
while(cy) lk[cy] = lk[pat[cy]], cy = pat[cy];
dfs(nn+,d1+(ch),d2+(ch^));
mv(lx,_lx), mv(ly,_ly), mv(lk,_lk);
}
}
int main()
{
int i,j;
n2 = (n = read())>>;
for(i=;i<=n;i++) for(j=;j<=n;j++) w1[i][j] = read();
for(i=;i<=n;i++) for(j=;j<=n;j++) w2[i][j] = read();
dfs(,,);
printf("%d\n",ans);
return ;
}

Bubble Cup 8 finals C. Party (575C)的更多相关文章

  1. Bubble Cup 12 - Finals Online Mirror, unrated, Div. 1

    Bubble Cup 12 - Finals Online Mirror, unrated, Div. 1 C. Jumping Transformers 我会状压 DP! 用 \(dp[x][y][ ...

  2. Bubble Cup 11 - Finals [Online Mirror, Div. 1]题解 【待补】

    Bubble Cup 11 - Finals [Online Mirror, Div. 1] 一场很好玩的题啊! I. Palindrome Pairs 枚举哪种字符出现奇数次. G. AI robo ...

  3. Bubble Cup 8 finals I. Robots protection (575I)

    题意: 有一个正方形区域, 要求支持两个操作: 1.放置三角形,给定放置方向(有4个方向,直角边与坐标轴平行),直角顶点坐标,边长 2.查询一个点被覆盖了多少次 1<=正方形区域边长n<= ...

  4. Bubble Cup 8 finals H. Bots (575H)

    题意: 简单来说就是生成一棵树,要求根到每个叶子节点上的路径颜色排列不同, 且每条根到叶子的路径恰有n条蓝边和n条红边. 求生成的树的节点个数. 1<=n<=10^6 题解: 简单计数. ...

  5. Bubble Cup 8 finals G. Run for beer (575G)

    题意: 给定一个带权无向图,每条边的代价为边权/当前速度,每次到达一个新节点,速度都会除以10. 求0号点到n-1号点的最小代价,如果多解输出点数最少的解,输出代价.路径点数.路径经过的点. 1< ...

  6. Bubble Cup 8 finals F. Bulbo (575F)

    题意: 给定初始位置,查询n次区间,每次查询前可以花费移动距离的代价来移动, 查询时需要花费当前位置到区间内最近的点的距离,求最小代价. 1<=n<=5000,1<=所有位置< ...

  7. Bubble Cup 8 finals E. Spectator Riots (575E)

    题意: 一个长宽是100000单位的球场上有很多暴动的观众,每个观众都有一个速度v, 在一秒内,观众会等概率地移动到与原位置的曼哈顿距离<=v的地方(不会移动到界外). 你需要选取三个位置,这三 ...

  8. Bubble Cup 8 finals D. Tablecity (575D)

    题意: (无输入,纯输出题) 一个城市用1000列2行的格子表示,一个小偷藏在城市的某一处. 在每一小时的开始, 在(X, Y)位置的小偷可以移动到 (X - 1, Y), (X + 1, Y),(X ...

  9. Bubble Cup 8 finals B. Bribes (575B)

    题意: 给定一棵n个点和有向边构成的树,其中一些边是合法边,一些边是非法边, 经过非法边需要1的费用,并且经过之后费用翻倍. 给定一个长为m的序列,问从点1开始按顺序移动到序列中对应点的总费用. 1& ...

随机推荐

  1. mysql笔记

    查看当前版本: SELECT VERSION(); 查看当前时间: SELECT NOW(); 查看当前当前用户: SELECT USER(); 创建数据库:CREATE DATABASE 数据库名字 ...

  2. HTTP Session、Cookie机制详解

    一.什么是http session,有什么用 HTTP协议本身是无状态的,本身并不能支持服务端保存客户端的状态信息,于是,Web Server中引入了session的概念,用来保存客户端的状态信息. ...

  3. Excel公式 提取文件路径后缀

    我们在代码中获取一个文件路径的后缀,是一个很简单的事. 如C#中,可以通过new FileInfo(filePath).Extension,或者Path.GetExtension(filePath)获 ...

  4. 【java开发】ubuntu常用命令及环境搭建

    学习第一天,今天内容相对简单,主要就是ubuntu一些常用命令及常规操作,后续涉及到环境的搭建,也会在本文再更. ubuntu环境搭建 第一种 也是最简单最方便的 通过vm虚拟机软件,下载iso镜像进 ...

  5. Jenkins——构建、集成中的问题

      准备 Jekins   安装插件 MsBuild Plugin Team Foundation Server Plug-in 配置环境变量 我的电脑中设置环境变量,Path中添加msbuild的路 ...

  6. iOS开发常用代码块

    遍历可变数组的同时删除数组元素 NSMutableArray *copyArray = [NSMutableArray arrayWithArray:array]; NSString *str1 = ...

  7. Android客户端和服务器端数据交互

    网上有很多例子来演示Android客户端和服务器端数据如何实现交互不过这些例子大多比较繁杂,对于初学者来说这是不利的,现在介绍几种代码简单.逻辑清晰的交互例子,本篇博客介绍第四种: 一.服务器端: 代 ...

  8. ZBrush中的头部模型该如何进行雕刻

    使用ZBrush®能够快速雕刻人物头部模型,教程只是大概介雕刻前的准备工作和一些软件基础,真正的雕刻还需要学习者具备一定的功底,本文向大家展示头部模型制作流程解析,初学者可以以它做参考拓展自己思路. ...

  9. 第9章 Shell基础(2)_Bash基本功能

    3. Bash的基本功能 3.1 历史命令与命令补全 (1)历史命令:#history [选项] [历史命令保存文件] ①选项:-c:清空历史命令: -w:把缓存中的历史命令写入文件~/.bash_h ...

  10. TCP/IP协议(二)tcp/ip基础知识

    今天凌晨时候看书,突然想到一个问题:怎样做到持续学习?然后得出这样一个结论:放弃不必要的社交,控制欲望,克服懒惰... 然后又有了新的问题:学习效率时高时低,状态不好怎么解决?这也是我最近在思考的问题 ...