bzoj2064
这道题初看真的毫无思路,又是合并又是分裂的
但实际上我们知道,当两组和相等的时候才能由一组变成另一组
我们将初始状态和最终状态划分成若干对,每对中的两组元素和相等的
不难发现,最少步骤=n+m-2*对数
因为在一对不能再划分的组中,具有k个元素变换到具有j个元素所花的最短步骤是k+j-2
于是问题就转化为了怎么划分,划分的对数最多
由于n,m<=10,这样我们就可以把选取状况用01二进制表示来解决了;
我们先算出每个状态的每种组合情况的和
f[x,y]表示初始状态选取状况为x,最终状态选取状况为y的时候,最多划分成的对数
然后方便转移,我们可以采用记忆化搜索的方式
这道题题解不大好表达,只可意会不可言传
var w,f:array[..,..] of longint;
sum,a,b,c:array[..] of longint;
n,m,i,j,s1,s2,s:longint;
function max(a,b:longint):longint;
begin
if a>b then exit(a) else exit(b);
end; function dfs(x,y:longint):longint;
var i,j,k:longint;
begin
if (x=s1) then
begin
if y<>s2 then exit(-)
else exit();
end;
if (y=s2) then
begin
if s1=x then exit()
else exit(-);
end;
if f[x,y]<>- then exit(f[x,y]); //记忆化
for i:= to s1 do
begin
if i and x= then
begin
k:=sum[i];
for j:= to c[k] do //在最终状态中找一个和初始状态的组合和相等的组形成新的一对
if w[k,j] and y= then
f[x,y]:=max(f[x,y],dfs(x xor i,y xor w[k,j])+);
end;
end;
exit(f[x,y]);
end; begin
read(n);
for i:= to n do
read(a[i]);
read(m);
for i:= to m do
read(b[i]);
s1:= shl n-;
s2:= shl m-;
for i:= to s1 do
for j:= to n- do
if i and ( shl j)> then
sum[i]:=sum[i]+a[j+];
for i:= to s2 do
begin
s:=;
for j:= to m- do
if i and ( shl j)> then
s:=s+b[j+];
inc(c[s]); //感觉这种做法很像Meet in middle
w[s,c[s]]:=i;
end;
fillchar(f,sizeof(f),);
writeln(n+m-*dfs(,));
end.
bzoj2064的更多相关文章
- 【BZOJ2064】分裂 状压DP
[BZOJ2064]分裂 Description 背景:和久必分,分久必和...题目描述:中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力.同时经常搞OI的他把这个变成了一个 ...
- bzoj2064[和谐社会模拟赛]分裂
题意:给定一个初始集合和目标集合,有两种操作:1.合并集合中的两个元素,新元素为两个元素之和 2.分裂集合中的一个元素,得到的两个新元素之和等于原先的元素.要求用最小步数使初始集合变为目标集合,求最小 ...
- BZOJ2064: 分裂
2064: 分裂 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 360 Solved: 220[Submit][Status][Discuss] De ...
- 【状压dp】Bzoj2064 分裂
Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力. 同时经常搞OI的他把这个变成了一个数学模型. 假设中 ...
- 2018.10.24 bzoj2064: 分裂(状压dp)
传送门 状压dp好题. 考虑对于两个给出的集合. 如果没有两个元素和相等的子集,那么只能全部拼起来之后再拆开,一共需要n1+n2−2n1+n2-2n1+n2−2. 如果有呢? 那么对于没有的就是子问题 ...
- 分裂 BZOJ2064 状压DP
分析: 这个题很好啊,比起什么裸的状压DP高多了! 我们可以考虑,什么时候答案最大:全合并,之后再分裂 这样,我们必定可以得到答案,也就是说答案必定小于n+m 那么我们可以考虑,什么时候能够使答案更小 ...
- BZOJ2064:分裂——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=2064 Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数 ...
- bzoj2064: 分裂(集合DP)
......咸鱼了将近一个月,因为沉迷ingress作业越来越多一直没时间搞OI呜呜呜 题目大意:有一个初始集合(n个元素)和一个目标集合(m个元素)(1<=n,m<=10),两个操作 ...
- 【bzoj2064】分裂【压状dp】
Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力. 同时经常搞OI的他把这个变成了一个数学模型. 假设中 ...
随机推荐
- Bash中的数组
变量:$VAR或者${VAR} 数组:${VAR[$i]} 打印整个数组:echo ${VAR[@]} 统计数组元素个数:echo ${#VAR[@]} 从文件读入数组(按行读入):VAR=(`cat ...
- ArcGIS 在地图上添加标注
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- AppCan中两种获取信息的方法
<div id="newsInfo">正在加载...</div> 1.JSON格式: [{'R': '1','NOTI_ID': '9','NOTI_TIT ...
- C#入门教程(二)–C#常用快捷键、变量、类型转换-打造C#学习教程
C#入门教程(一)–.Net平台技术介绍.C#语言及开发工具介绍-打造C#学习教程 上次教程主要介绍了.Net平台以及C#语言的相关介绍.以及经典程序案例,helloworld程序. 初来乍到,第一次 ...
- 浅谈负载均衡之【tomcat分布式session共享】
1)整理集成所需jar kryo-1.0.3.jar kryo-serializers-0.8.jar memcached-2.4.2.jar memcached-session-manager-1. ...
- Js 的常用方法:页面跳转,Session,类继承
MyApp.Base = function () { } var basePrototype = MyApp.Base["prototype"]; //对象克隆方法 basePro ...
- CentOS PHP-5.4.8 编译安装之初体验
1. 下载5.4.8 版本 [root@Test data] wget http://museum.php.net/php5/php-5.4.8.tar.gz 2. 解压 [root@Test php ...
- 深入理解shared pool共享池之library cache系列二
背景 继续上文:深入理解shared pool共享池之library cache系列一,学习library cache数据结构,本文主要学习library cache object(lco)的数据结构 ...
- oracle 权限管理
系统权限 系统权限需要授予者有进行系统级活动的能力,如连接数据库,更改用户会话.建立表或建立用户等等.你可以在数据字典视图SYSTEM_PRIVILEGE_MAP上获得完整的系统权限.对象权限和系统权 ...
- 前端----表格的具体使用(jquery)
表格在页面布局中常常会用到.在不同的框架中有不同的使用方法,现在,我先总结下表格在jquery中具体使用: 1.增--insertAfter() function addTr(){ $("& ...