%%%%orz苏大佬 虽然苏大佬的baff吸不得,苏大佬的梦信不得,但是膜苏大佬是少不得的囧

这题还是比较有收获的 哼居然有我不会做的插头DP

自己yy了下,2表示属于2的插头,3表示3的插头

假如当前是0点,并且没有左上连向,那么可以不放插头,也可以放2放3,否则就是常规操作

假如是障碍那就不能有插头

然后假如是2和3点,就可以放个单插头,或者直接继承前面的插头

我觉得很OK啊。。。然后就不会记录ans了

????黑人问号啊,怎么判是否结束了啊

写了各种异或判断是否当前状态把四个位置都放了,然后。。就只能过这个↓

2 3
2 2 0
0 3 3

直接去%苏大佬的code,发现她是这么写的:

ans=;
work();
for(int i=;i<=dp[now].size;i++)
{
ans+=dp[now].num[i];//将所有可行的方案加入ans
}
printf("%lld\n",ans>?ans-:);

她怎么能直接把状态的最小值累加啊???

调试了一下发现,这个栈里面的元素要么只有一个要么没有要你这个for何用啊

彻底懵逼。。直接去膜拜   终于懂了

是因为到最后肯定只有一个状态,就是0(也就是匹配完成),假如不匹配完成那么就不会成功继承。

那我现在的感觉是其他题是不是也一样?假如我让它不合法就不继承好像可以一样做欸

upd:我在做下一题的时候发现我好像沙茶了,因为每道题情况不一样,对于这题而言,它不需要形成回路,并且可以有空格不行经,使得它在转移的时候可以空转移,所以能够无需特判直接转移到末尾

整理下思路,一开始我想的是分开算2和3的长度,这个很难实现,因为它们不相交所以我只需要求放了插头的位置数就行了,对于继承答案可以直接转移到最后一个位置,中途继承判合法就行了

为什么每次写s=set_bracket(s,j,q);都特别想笑。。。我也想把LCT改成YZH

#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
typedef long long LL;
const LL mod=; int n,m;
int mp[][];
struct node
{
LL mn[];
int top;LL hash[],sta[];
void pha(int s,LL mmin)
{
int x=s%mod;
while(hash[x]!=&&sta[hash[x]]!=s)x=(x+)%mod;
if(hash[x]==)sta[++top]=s,hash[x]=top;
mn[hash[x]]=min(mn[hash[x]],mmin);
}
void clean()
{
top=;
memset(mn,,sizeof(mn));
memset(hash,,sizeof(hash));
}
}dp[];
LL get_bracket(LL s,LL p)
{
return (s>>((p-)*))&;
}
LL set_bracket(LL s,LL p,LL v)
{
s^=(get_bracket(s,p)<<((p-)*));
s^=(v<<((p-)*));
return s;
}
int pre,now;
void Plug_DP()
{
pre=,now=;
dp[now].clean();dp[now].pha(,);
for(LL i=;i<=n;i++)
{
for(LL j=;j<=m;j++)
{
swap(pre,now);dp[now].clean();
for(int k=;k<=dp[pre].top;k++)
{
LL s=dp[pre].sta[k],mn=dp[pre].mn[k];
LL p=get_bracket(s,j),q=get_bracket(s,j+); if(mp[i][j]==)
{
if(p==&&q==)dp[now].pha(s,mn);
}
else if(mp[i][j]==)
{
if(p==&&q==)
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,);
dp[now].pha(s,mn);
if(mp[i][j+]!=&&mp[i+][j]!=)
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
s=set_bracket(s,j,);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
}
else if(p==&&q>)
{
if(mp[i+][j]!=)
{
s=set_bracket(s,j,q);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
if(mp[i][j+]!=)
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,q);
dp[now].pha(s,mn+);
}
}
else if(p>&&q==)
{
if(mp[i+][j]!=)
{
s=set_bracket(s,j,p);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
if(mp[i][j+]!=)
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,p);
dp[now].pha(s,mn+);
}
}
else if(p>&&q>)
{
if(p==q)
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
}
}
else
{
if(p==&&q==)
{
if(mp[i][j+]==||mp[i][j+]==mp[i][j])
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,mp[i][j]);
dp[now].pha(s,mn+);
}
if(mp[i+][j]==||mp[i+][j]==mp[i][j])
{
s=set_bracket(s,j,mp[i][j]);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
}
if((p==&&q==mp[i][j])||(p==mp[i][j]&&q==))
{
s=set_bracket(s,j,);
s=set_bracket(s,j+,);
dp[now].pha(s,mn+);
}
}
}
}
for(int k=;k<=dp[now].top;k++)
dp[now].sta[k]<<=;
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n==&&m==)break;
memset(mp,,sizeof(mp));
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
scanf("%d",&mp[i][j]);
if(mp[i][j]==||mp[i][j]==)mp[i][j]^=;
}
}
Plug_DP();
printf("%lld\n",(dp[now].top==)?:(dp[now].mn[]-));
}
return ;
}

caioj1496: [视频]基于连通性状态压缩的 动态规划问题:Manhattan Wiring的更多相关文章

  1. caioj1495: [视频]基于连通性状态压缩的 动态规划问题:Formula 2

    本来想写一天插头的,但是这题太难受(绝望)500+的代码量..我选择下午放松一下. 先ORZ一下苏大佬(yz的cdq啊%%%%%)居然把cdq论文里面的题抠出来出数据放在c站(呵呵真是个悲伤的故事不过 ...

  2. 插头DP(基于连通性状态压缩的动态规划问题)(让你从入门到绝望)

    今天,我,Monkey king 又为大家带来大(ju)佬(ruo)的算法啦!--插头DP 例题(菜OJ上的网址:http://caioj.cn/problem.php?id=1489): 那么,这道 ...

  3. 【BZOJ2734】【HNOI2012】集合选数(状态压缩,动态规划)

    [BZOJ2734][HNOI2012]集合选数(状态压缩,动态规划) 题面 Description <集合论与图论>这门课程有一道作业题,要求同学们求出{1, 2, 3, 4, 5}的所 ...

  4. 【NOIP2017】宝藏(状态压缩,动态规划)

    [NOIP2017]宝藏(状态压缩,动态规划) 题面 洛谷 题目描述 参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 n 个深埋在地下的宝藏屋, 也给出了这 n 个宝藏屋之间可供开发的 m 条道路 ...

  5. 洛谷P2258 子矩阵 题解 状态压缩/枚举/动态规划

    作者:zifeiy 标签:状态压缩.枚举.动态规划 题目链接:https://www.luogu.org/problem/P2258 这道题目状态压缩是肯定的,我们需要用二进制来枚举状态. 江湖上有一 ...

  6. HOJ-2662Pieces Assignment(状态压缩,动态规划)

    Pieces Assignment Source : zhouguyue Time limit : 1 sec Memory limit : 64 M Submitted : 415, Accepte ...

  7. 【NOI2001】炮兵阵地(状态压缩,动态规划)

    题面 题面中有图片的存在,所以就贴个地址把 题解 简单题,,,, 原来一直觉得不会做... 现在发现是一道傻逼题 暴力压两行的状态 发现就需要滚一维. 然后暴力检查一下状态的可行性 DP检查MAX就可 ...

  8. 【BZOJ1087】【SCOI2005】互不侵犯(状态压缩,动态规划)

    题面 这种傻逼题懒得粘贴了... 题解 傻逼题 \(f[i][j][k]\)表示当前第\(i\)列,当前放置状态为\(j\),已经放了\(k\)个 暴力判断状态合法性,暴力判断转移合法性,然后统计答案 ...

  9. HDU-4539郑厂长系列故事——排兵布阵(状态压缩,动态规划)

    郑厂长系列故事--排兵布阵 Time Limit : 10000/5000ms (Java/Other) Memory Limit : 65535/32768K (Java/Other) Total ...

随机推荐

  1. Python中断言与异常的区别

    异常,在程序运行时出现非正常情况时会被抛出,比如常见的名称错误.键错误等. 异常: >>> s Traceback (most recent call last): File &qu ...

  2. mysql 1862 密码过期

    1.管理员权限运行命令: cmd mysqladmin -uroot -p password 修改密码. 2.设置密码永不过期. mysql 数据库\ user 表\ password_expired ...

  3. oracle 表锁定解锁

    Oracle数据库操作中,我们有时会用到锁表查询以及解锁和kill进程等操作,那么这些操作是怎么实现的呢?本文我们主要就介绍一下这部分内容.(1)锁表查询的代码有以下的形式:select count( ...

  4. ie6 中文字符编码 出现的问题解决

    0 前言   公司要求网页要支持ie6.7.8,结果我的设备在ie7.8.9均工作正常,而在ie6时就出现各种奇怪的错误,在这个背景下,开始动手解决网页不兼容ie6的情况.   1 搭建ie6的实验平 ...

  5. strusts2_json

    引用别人的 Struts.xml <package name="default" extends ="json-default" > <act ...

  6. VMware 虚拟化技术 创建虚拟机

    原文地址:https://www.linuxidc.com/Linux/2017-03/141972.htm 云最成熟的架构是IaaS(Infrastructure as a Service),其中用 ...

  7. 数据结构(3) 第三天 栈的应用:就近匹配/中缀表达式转后缀表达式 、树/二叉树的概念、二叉树的递归与非递归遍历(DLR LDR LRD)、递归求叶子节点数目/二叉树高度/二叉树拷贝和释放

    01 上节课回顾 受限的线性表 栈和队列的链式存储其实就是链表 但是不能任意操作 所以叫受限的线性表 02 栈的应用_就近匹配 案例1就近匹配: #include <stdio.h> in ...

  8. WSDL实例解析

    WSDL的主要文档元素 WSDL文档可以分为两部分.顶部分由抽象定义组成,而底部分则由具体描述组成.抽象部分以独立于平台和语言的方式定义SOAP消息,它们并不包含任何随 机器或语言而变的元素.这就定义 ...

  9. JavaScript进阶【一】JavaScript模块化开发的基础知识

    //模块化的最初写法 //1.最初写法 //下面的m1和m2就组成了一个模块 //缺点:"污染"了全局变量,无法保证不与其他模块发生变量名冲突,而且模块成员之间看不出直接关系. f ...

  10. Iterator和for...of

    Iterator和for...of 什么是Iterator ES6中的Map 和 Set ,再加上之前的数组和对象,这样就有了四种数据集合,用户可以组合使用它们,定义自己的数据结构.这时,我们就需要一 ...