这道题初看真的毫无思路,又是合并又是分裂的

但实际上我们知道,当两组和相等的时候才能由一组变成另一组

我们将初始状态和最终状态划分成若干对,每对中的两组元素和相等的

不难发现,最少步骤=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的更多相关文章

  1. 【BZOJ2064】分裂 状压DP

    [BZOJ2064]分裂 Description 背景:和久必分,分久必和...题目描述:中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力.同时经常搞OI的他把这个变成了一个 ...

  2. bzoj2064[和谐社会模拟赛]分裂

    题意:给定一个初始集合和目标集合,有两种操作:1.合并集合中的两个元素,新元素为两个元素之和 2.分裂集合中的一个元素,得到的两个新元素之和等于原先的元素.要求用最小步数使初始集合变为目标集合,求最小 ...

  3. BZOJ2064: 分裂

    2064: 分裂 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 360  Solved: 220[Submit][Status][Discuss] De ...

  4. 【状压dp】Bzoj2064 分裂

    Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力. 同时经常搞OI的他把这个变成了一个数学模型. 假设中 ...

  5. 2018.10.24 bzoj2064: 分裂(状压dp)

    传送门 状压dp好题. 考虑对于两个给出的集合. 如果没有两个元素和相等的子集,那么只能全部拼起来之后再拆开,一共需要n1+n2−2n1+n2-2n1+n2−2. 如果有呢? 那么对于没有的就是子问题 ...

  6. 分裂 BZOJ2064 状压DP

    分析: 这个题很好啊,比起什么裸的状压DP高多了! 我们可以考虑,什么时候答案最大:全合并,之后再分裂 这样,我们必定可以得到答案,也就是说答案必定小于n+m 那么我们可以考虑,什么时候能够使答案更小 ...

  7. BZOJ2064:分裂——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=2064 Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数 ...

  8. bzoj2064: 分裂(集合DP)

    ......咸鱼了将近一个月,因为沉迷ingress作业越来越多一直没时间搞OI呜呜呜 题目大意:有一个初始集合(n个元素)和一个目标集合(m个元素)(1<=n,m<=10),两个操作   ...

  9. 【bzoj2064】分裂【压状dp】

    Description 背景: 和久必分,分久必和... 题目描述: 中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力. 同时经常搞OI的他把这个变成了一个数学模型. 假设中 ...

随机推荐

  1. 爆牙齿的 Web 标准面试题 【转藏】

    <!DOCTYPE html> <html lang="zh-CN"><head> <meta http-equiv="cont ...

  2. Mysql INNER,LEFT ,RIGHT join的使用

    JOIN 按照功能大致分为如下三类: INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录. LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录. RIG ...

  3. [GDI+] 生成缩略图的类文件SmallImage (转载)

    直接看代码吧,大家可以直接复制使用 /// <summary> /// 类说明:SmallImage类, /// 编码日期:2012-08-20 /// 编 码 人: 苏飞 /// 联系方 ...

  4. Windows Azure 试用 for 世纪互联运维

    前一段时间申请由世纪互联运维的和谐版Windows Azure的邀请嘛下来,今天花费了点时间注册了一下 注册邀请函, 根据提示输入邀请码之后会收到以下邮件 中国地区可选择建立的虚拟机,SQL Serv ...

  5. Android简单例子——AlertDialog

    最近学习了一段时间的Android,在网上找了些小的Demo,自己模拟这做了下,首先谢谢那些提供例子的朋友 今天主要学习的是简单的Dialog的使用(实现退出对话框)和自定义对话框 1.实现退出对话框 ...

  6. C#中如何正确的操作字符串?

    字符串应该是所有编程语言中使用最频繁的一种基础数据类型.如果使用不慎,我们就会为一次字符串的操作所带来的额外性能开销而付出代价.本条建议将从两个方面来探讨如何规避这类性能开销: 1. 确保尽量少的装箱 ...

  7. mahout分类

    分类看起来比聚类和推荐麻烦多了 分类算法与聚类和推荐算法的不同:必须是有明确结果的,必须是有监督的,主要用于预测和检测 Mahout的优势 mahout的分类算法对资源的要求不会快于训练数据和测试数据 ...

  8. WinpCap 使用线程发数,明明发了,返回值0是OK的啊,怎么抓包看不到,难道不支持多线程。。。

    if (!m_adapterHandle){    return false;}int rst = pcap_sendpacket((pcap_t*)m_adapterHandle,data ,dat ...

  9. 寒假的ACM训练(一)

    今天开始ACM训练,选择了刘汝佳的<挑战编程>,暂时算是开始了. 测评的网址: http://www.programming-challenges.com 第一个题目是水题啦.3n+1. ...

  10. 中文翻译:pjsip教程(二)之ICE穿越打洞:Interactive Connectivity Establishment简介

    1:pjsip教程(一)之PJNATH简介 2:pjsip教程(二)之ICE穿越打洞:Interactive Connectivity Establishment简介 3:pjsip教程(三)之ICE ...