\(\text{Solution}\)

一眼不会,限制有点多。。。

那就网络流

发下确实是很简单的建图

枚举起点集合

拆点后就很好满足限制了

\(\text{Code}\)

#include <cstdio>
#include <iostream>
#include <cstring>
#define RE register
#define IN inline
using namespace std; const int N = 1005, INF = 2147483647;
int n, m, S, T, num, p1, p2, tot, ans;
int dis[N], h[N], vis[N], pre[N], edge[N], flow[N], a[25][25], d[N], buc[N], Q[N];
int fx[4][2] = {{1, 0}, {0, 1}, {-1, 0}, {0, -1}};
char str[20];
struct node{int to, nxt, w, f;}e[N * 10];
IN void add(int u, int v, int w, int f)
{
e[++tot] = node{v, h[u], w, f}, h[u] = tot;
e[++tot] = node{u, h[v], 0, -f}, h[v] = tot;
}
IN int Isin(int x, int y){return (x > 0 && x <= n && y > 0 && y <= m && a[x][y] != 101);}
IN int getid(int x, int y){return (x - 1) * m + y;} IN int spfa()
{
for(RE int i = S; i <= T; i++) vis[i] = 0, dis[i] = flow[i] = INF;
int head = 0, tail = 1;
d[1] = S, vis[S] = 1, dis[S] = 0, pre[T] = -1;
while (head < tail)
{
int now = d[++head];
vis[now] = 0;
for(RE int i = h[now]; i; i = e[i].nxt)
if (dis[e[i].to] > dis[now] + e[i].f && e[i].w)
{
dis[e[i].to] = dis[now] + e[i].f, flow[e[i].to] = min(flow[now], e[i].w), pre[e[i].to] = now, edge[e[i].to] = i;
if (!vis[e[i].to]) vis[e[i].to] = 1, d[++tail] = e[i].to;
}
}
return pre[T] != -1;
}
IN int MCMF()
{
int now, Maxflow = 0, Mincost = 0;
while (spfa())
{
Maxflow += flow[T], Mincost += dis[T] * flow[T], now = T;
while (now != S) e[edge[now]].w -= flow[T], e[edge[now] ^ 1].w += flow[T], now = pre[now];
}
if (Maxflow != num / 2) return INF;
return Mincost;
} IN void solve()
{
memset(h, 0, sizeof h), tot = 1, T = n * m * 2 + 1;
for(RE int i = 1; i <= n; i++)
for(RE int j = 1; j <= m; j++)
if (a[i][j] != 101)
{
if (a[i][j] == 100) add(getid(i, j), getid(i, j) + n * m, 1, 1);
else add(getid(i, j), getid(i, j) + n * m, 1, 0);
for(RE int k = 0; k < 4; k++)
{
int x = i + fx[k][0], y = j + fx[k][1];
if (Isin(x, y)) add(getid(i, j) + n * m, getid(x, y), 1, 0);
}
}
for(RE int i = 1; i <= num; i++)
if (buc[Q[i]]) add(S, Q[i], 1, 0);
else add(Q[i] + n * m, T, 1, 0);
ans = min(ans, MCMF());
} void dfs(int x, int s)
{
if (s > num / 2) return;
if (x > num)
{
if (s == num / 2 && ((!p1 && !p2) || (buc[p1] && buc[p2]))) solve();
return;
}
buc[Q[x]] = 1, dfs(x + 1, s + 1), buc[Q[x]] = 0, dfs(x + 1, s);
} int main()
{
int q; scanf("%d", &q);
for(; q; --q)
{
memset(buc, 0, sizeof buc), num = p1 = p2 = 0, ans = INF, scanf("%d%d", &n, &m);
for(RE int i = 1; i <= n; i++)
{
scanf("%s", str + 1);
for(RE int j = 1, id; j <= m; j++)
if (str[j] == '.') a[i][j] = 100;
else if (str[j] == '#') a[i][j] = 101;
else
{
a[i][j] = str[j] - 'A' + 1, id = getid(i, j), Q[++num] = id;
if (buc[a[i][j]]) p1 = buc[a[i][j]], p2 = id;
buc[a[i][j]] = id;
}
}
memset(buc, 0, sizeof buc), dfs(1, 0), printf("%d\n", (ans == INF ? -1 : ans));
}
}

JZOJ 3281. 【GDOI2013】字母连接的更多相关文章

  1. LODOP字体不识别 英文字母连起来 引号不正常

    打印超文本的时候,有时候会发现html中设置的css样式显示不正常,字体根本不是设置的字体,这种情况有可能是:1.该操作系统没有安装自己指定的那种字体,那么没有安装自然就不能显示设置的字体.2.该操作 ...

  2. Leetcode17--->Letter Combinations of a Phone Number(电话号码对应的字母的组合)

    题目: 给定一个数字字符串,返回数字所能代表的所有字母组合: 举例: Input:Digit string "23" Output: ["ad", " ...

  3. EasyPR--开发详解(4)形态学操作、尺寸验证、旋转等操作

    在上一篇深度分析与调优讨论中,我们介绍了高斯模糊,灰度化和Sobel算子.在本文中,会分析剩余的定位步骤. 根据前文的内容,车牌定位的功能还剩下如下的步骤,见下图中未涂灰的部分. 图1 车牌定位步骤 ...

  4. pythonchallenge(二)

    PythonChallenge_2 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux ...

  5. Lua中的捕获

    Lua中的捕获   捕获 捕获是这样一种机制:可以使用模式串的一部分匹配目标串的一部分.将你想捕获的模式用圆括号括起来,就指定了一个捕获.在string.find使用捕获的时候,函数会返回捕获的值作为 ...

  6. bzoj2537: [neerc2007]Language Recognition

    Description DFA(确定性有限状态自动机)是一个有向图,顶点称为状态,边称为转移.每个转移用一个字母标记.对于每个状态s和每个转移l,至多有一个转移从s出发且标记为l.DFA有一个初始状态 ...

  7. 惊艳的随机化方法 -World Search (homework-04)

    homeword04-word search 0. 摘要 本次作业,要求完成一个word search的程序,具体要求是: 输入:一个包含20-60个单词的文件,各单词不大于20个字母,无空格. 输出 ...

  8. 辛星浅谈PHP的混乱的编码风格

    我们都知道.各种编程语言都有自己的风格,即使是像C和C++那样一脉相承的语言(C++本意全然兼容C的语法).编程风格上还是有些区别.比方非常典型的就是C++风格的单行凝视和C风格的多行凝视. 而尽管J ...

  9. Vim文本编辑器 指令簿(二)

    常常处理文本以及常常须要写代码的人,都会有自己比較常常使用的编辑器,本人喜欢用Vim.理由就是Vim编辑器灵活,而且能够达到纯键盘操作,使用纯熟情况下,根本不须要鼠标操作.听起来是不是非常酷的?只是别 ...

  10. EasyPR--开发详解

    我正在做一个开源的中文车牌识别系统,Git地址为:https://github.com/liuruoze/EasyPR. 我给它取的名字为EasyPR,也就是Easy to do Plate Reco ...

随机推荐

  1. IDEA把项目推送到Gitee

    1.在gitee注册账户:QQ注册就是:QQ邮箱和密码 2.新建一个自己的仓库 3.打开本地的IDEA中的项目 4.添加git项目标记||前提都是IDEA已关联你的GIt软件 5.查看git项目标记是 ...

  2. 解决python3解压文件名乱码问题(unzip)

    看来很多文章,不过我觉得最有效的还是改源码,因为我用的sublime text 3有插件Anaconda可以很方便的跳转到源码文件,你也可以入python3 的安装目录, 搜索 zipfile.py这 ...

  3. JDK中内嵌JS引擎介绍及使用

    原文: JDK中内嵌JS引擎介绍及使用 - Stars-One的杂货小窝 最近研究阅读这个APP,其主要功能就是通过一个个书源,从而实现移动端阅读的体验 比如说某些在线小说阅读网站,会加上相应的广告, ...

  4. Python Excel 处理模块 : OpenPyXL

    OpenPyXL模块使用方法 以下是介绍OpenPyXL的基本使用,不涉及样式和合并单元格的跨行操作 一般来说,对于大名鼎鼎的xlrd,xlwt和xlutils三个模块,Excel操作有3个基本状态 ...

  5. 万字干货|Synchronized关键字详解

    作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.JAVA底层.面试.职业成长相关资料等更多精彩文章在公众号「小牛呼噜噜」 前言 大家好,我是呼噜噜,在之前的文章中 ...

  6. 当 xxl-job 遇上 docker → 它晕了,但我不能乱!

    开心一刻 某次住酒店,晚上十点多叫了个外卖 过了一阵儿,外卖到了 因为酒店电梯要刷卡,所以我下楼去接 到了电梯口看到个模样不错的妹纸 我:是你么? 妹纸愣了下:嗯! 于是拉上进电梯回房间,正准备开始呢 ...

  7. 15、MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction

    转载自 一.报错信息: Error updating database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollback ...

  8. 希腊字母表及latex代码

    希腊字母表及latex代码 字母大写 字母小写 英文名称 latex大写代码 latex小写代码 \(\Alpha\) \(\alpha\) alpha \Alpha \alpha \(\Beta\) ...

  9. 字符编码:Unicode & UTF-16 & UTF-8

    ASCII码 使用一个字节(8位),对128个字符进行编码: 最高位始终为0: 码数范围为0000_0000(0x00)到0111_1111(0x7F): Unicode 开始的编码设计 使用两个字节 ...

  10. Curve 文件存储在 Elasticsearch 冷热数据存储中的应用实践

    Elasticsearch在生产环境中有广泛的应用,本文介绍一种方法,基于网易数帆开源的Curve文件存储,实现Elasticsearch存储成本.性能.容量和运维方面的显著提升. ES 使用 Cur ...