题解

给一个

n

\tt n

n 个点的完全有向图,

(

u

,

v

)

\tt(u,v)

(u,v) 或者

(

v

,

u

)

\tt(v,u)

(v,u) 都有一条边,前提是

u

v

\tt u\not=v

u​=v 。

每条边的边权是字符 a 或字符 b ,会给你一个

n

×

n

\tt n\times n

n×n 的二维字符表

G

\tt G

G 来表示它们,若

i

j

\tt i\not=j

i​=j ,则

G

i

,

j

=

a

\tt G_{i,j}=a

Gi,j​=a 或

G

i

,

j

=

b

\tt G_{i,j}=b

Gi,j​=b ,否则

G

i

,

j

=

\tt G_{i,j}=*

Gi,j​=∗ ,表示该边不存在。

现在问你,从任意一个起点开始,走

m

\tt m

m 步(可以经过重复的点或边)形成的字符串,是否可以为回文串?如果有,输出行走方案。

T

500

\tt T\leq 500

T≤500 组数据,

n

1000

,

m

1

0

5

\tt \sum n\leq1000,\sum m\leq10^5

∑n≤1000,∑m≤105 。

题解

一眼看过去,貌似是道

D

P

\tt DP

DP ?以前做过路径为回文串的题。

但是这题没必要,因为评分只有2000,明显可以直接分类讨论。

对于

m

\tt m

m 是奇数的情况,我们可以任意找两个点,反复跳,容易发现结果定是回文串。也就是说,这种情况下一定有解。

如果

m

\tt m

m 是偶数,这样讨论:

  • 若存在一对点

    u

    ,

    v

    \tt u,v

    u,v ,满足

    G

    u

    ,

    v

    =

    G

    v

    ,

    u

    \tt G_{u,v}=G_{v,u}

    Gu,v​=Gv,u​ ,那么直接在这两个点之间跳。这明显是无懈可击的方案。

  • 否则,整个图满足对于任意两个不相等的点

    u

    ,

    v

    \tt u,v

    u,v ,

    G

    u

    ,

    v

    ,

    G

    v

    ,

    u

    \tt G_{u,v},G_{v,u}

    Gu,v​,Gv,u​ 其中一个是 a ,另一个是 b 。然后,我们找这么三个点

    x

    ,

    y

    ,

    z

    \tt x,y,z

    x,y,z (

    x

    y

    ,

    y

    z

    \tt x\not=y,y\not=z

    x​=y,y​=z),满足

    G

    x

    ,

    y

    =

    G

    y

    ,

    z

    \tt G_{x,y}=G_{y,z}

    Gx,y​=Gy,z​,令这两条边为最中心的两条边,那么整个回文串为

    .

    .

    .

    G

    x

    ,

    y

    G

    y

    ,

    x

    G

    x

    ,

    y

    (

    m

    i

    d

    d

    l

    e

    )

    G

    y

    ,

    z

    G

    z

    ,

    y

    G

    y

    ,

    z

    .

    .

    .

    \tt ...G_{x,y}G_{y,x}~G_{x,y}(middle)G_{y,z}~G_{z,y}G_{y,z}...

    ...Gx,y​Gy,x​ Gx,y​(middle)Gy,z​ Gz,y​Gy,z​... ,左右两边都是交替出现的 ab ,且保证回文。

  • 如果这三个点也找不到,那么说明不论这一步是什么字符,下一步一定是不一样的字符。这样是形不成偶数长度的回文串的,此时无解。

复杂度

Θ

(

m

)

\tt\Theta(m)

Θ(m) 。

CODE

#include<set>
#include<queue>
#include<bitset>
#include<cmath>
#include<ctime>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 1005
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
#define INF 0x3f3f3f3f
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
char g[MAXN][MAXN];
int as[MAXN];
int main() {
int T = read();
while(T --) {
n = read();m = read();
for(int i = 1;i <= n;i ++) {
scanf("%s",g[i] + 1);
}
if(m & 1) {
printf("YES\n");
for(int i = 1;i <= m+1;i ++) printf("%d ",2-(i&1));ENDL;
}
else {
s = o = 0;
for(int i = 1;i <= n;i ++) {
for(int j = 1;j <= n;j ++) {
if(g[i][j] == g[j][i] && i != j) {s = i;o = j;break;}
}
}
if(s && o) {
printf("YES\n");
for(int i = 1;i <= m+1;i ++) printf("%d ",(i&1) ? s:o);ENDL;
}
else {
int cen = 0;
s = o = 0;
for(int i = 1;i <= n;i ++) {
int pa = 0,pb = 0;
for(int j = 1;j <= n;j ++) {
if(g[j][i] == 'a') pa = j;
if(g[j][i] == 'b') pb = j;
}
for(int j = 1;j <= n;j ++) {
if(g[i][j] == 'a' && pa) {s = pa;o = j;}
if(g[i][j] == 'b' && pb) {s = pb;o = j;}
}
if(s && o) {cen = i;break;}
}
if(cen) {
printf("YES\n");
m ++;
int md = (m+1)/2;
as[md] = cen;
as[md-1] = s;
as[md+1] = o;
for(int i = md-2;i > 0;i --) {
if(as[i+1] == s) as[i] = cen;
else as[i] = s;
}
for(int i = md+2;i <= m;i ++) {
if(as[i-1] == o) as[i] = cen;
else as[i] = o;
}
for(int i = 1;i <= m;i ++) printf("%d ",as[i]);ENDL;
}
else printf("NO\n");
}
}
}
return 0;
}

[CF1481D] AB Graph(构造)的更多相关文章

  1. HDU 4725 The Shortest Path in Nya Graph [构造 + 最短路]

    HDU - 4725 The Shortest Path in Nya Graph http://acm.hdu.edu.cn/showproblem.php?pid=4725 This is a v ...

  2. CodeForces 916C Jamie and Interesting Graph (构造)

    题意:给定两个数,表示一个图的点数和边数,让你构造出一个图满足 1-  n 的最短路是素数,并且最小生成树也是素数. 析:首先 1 - n 的最短路,非常好解决,直接 1 连 n 就好了,但是素数尽量 ...

  3. CodeForces 404C Restore Graph (构造)

    题意:让人构造一个图,满足每个结点边的数目不超过 k,然后给出每个结点到某个结点的最短距离. 析:很容易看出来如果可能的话,树是一定满足条件的,只要从头开始构造这棵树就好,中途超了int...找了好久 ...

  4. 2017icpc乌鲁木齐网络赛Colored Graph (构造)

    题目 https://nanti.jisuanke.com/t/16958 题意 给定一个n(n<=500)个点的无向图,给每条边黑白染色,输出同色三角形最少的个数和对应的方案 分析 首先考虑给 ...

  5. 2021record

    2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...

  6. HDU4467:Graph(点的度数分块)

    传送门 题意 给出一张n个点m条边的无向图,点的颜色为0/1,每次有两种操作: 1.Asksum x y,查询两点颜色为x和y的边的权值之和 2.Change x,将x颜色取反 分析 最直接的做法是每 ...

  7. CF1481X Codeforces Round #699

    C Fence Painting(构造) 有用的刷子贪心刷,没用的刷子填在后续的有用/已存在的位置(用个栈记一下就行) D AB Graph(图上构造) 把边当做三种类型,aa bb ab m为奇数时 ...

  8. Leetcode#115 Distinct Subsequences

    原题地址 转化为求非重路径数问题,用动态规划求解,这种方法还挺常见的 举个例子,S="aabb",T="ab".构造如下地图("."表示空位 ...

  9. Android内存泄漏分析及调试

    尊重原创作者,转载请注明出处: http://blog.csdn.net/gemmem/article/details/13017999 此文承接我的另一篇文章:Android进程的内存管理分析 首先 ...

随机推荐

  1. Git使用 - 忽略特定文件 - gitignore

    1. 背景 2. 创建.gitignore 文件 3. 文件内容样式 4. exclude文件 5. gitignore 文件模板 6. 参考文档 1. 背景 前提知识:在工作目录下的每一个文件都不外 ...

  2. Visual Studio 2010 ~ 2022 全系列密钥

    更新记录 2022年6月10日 修改序列号顺序. Visual Studio 2022 Professional(专业版): TD244-P4NB7-YQ6XK-Y8MMM-YWV2J Enterpr ...

  3. 25.MYsql数据库管理

    MYsql数据库管理 目录 MYsql数据库管理 数据库基本操作 库和表 常用的数据类型 查看数据表结构 查看当前服务器的数据库 查看数据库中包含的表 查看表的结构 SQL语句 创建及删除数据库和表 ...

  4. 18.Tomcat部署及优化

    Tomcat部署及优化 目录 Tomcat部署及优化 Tomcat简介 Tomcat核心组件 Web容器 什么是 servlet? 什么是 JSP? Container 结构分析 Tomcat 请求过 ...

  5. 全新升级的AOP框架Dora.Interception[1]: 编程体验

    多年之前利用IL Emit写了一个名为Dora.Interception(github地址,觉得不错不妨给一颗星)的AOP框架.前几天利用Roslyn的Source Generator对自己为公司写的 ...

  6. robotframework之环境安装

    一.安装python2.7环境,python --version查询python安装的版本 二.setuptools安装

  7. BUUCTF-秘密文件

    秘密文件 根据提示得知是属于文件被下载了,查看了下流量包直接过滤ftp包 这里看到有个RAR包存在,应该是隐写了 使用foremost分离即可 得到压缩包存在密码 默认四位纯数字爆破即可 flag{d ...

  8. 集成学习——XGBoost(手推公式)

  9. SAP SD-Invoice 销售发票

    针对销售订单的发票流程: 1. 事务码:VF01(个别生成系统发票) 创建开票凭证(发票)/  VF04 开具系统发票(可把多个item 合并成一张系统发票) 2. 事务码:VF02 修改发票, 释放 ...

  10. IP寻址与规划

    一.IP寻址和子网划分 IP地址的主机部分可被分为三种地址:网络地址.主机地址和定向广播地址. 网络地址是网络号中的第一个地址.它用来将网络内的其他所有网段唯一标识为一个网段或广播域.定向广播地址是网 ...