CF1506C Double-ended Strings 题解

技术CF1506C Double-ended Strings 题解 CF1506C Double-ended Strings 题解CF1506C Double-ended Strings 题解Conte

CF1506C双端字符串问题的解释

CF1506C双端字符串问题的解释

Content

有两个字符串\(a,b\)。我们可以在每次操作中删除两个字符串之一(可以将某个字符串通过若干次操作变为空串)的第一个或最后一个字符。需要多少次操作才能使\(a,b\)两个字符串相同?

数据范围:\(t\) 组数据,\(1\leqslant t\leqslant 100\),\(1\leqslant |a|,|b|\leqslant 20\)。

Solution

我们发现只要你能找到\(a,b\)两个字符串之间的公共部分,你只需要删除除了这个公共部分之外的其他部分,所以这个问题本质上是要求我们找到\(a,b\)的最长公共子串的长度。而且因为\(a,b\)的长度很小,所以我们考虑直接枚举。

首先,枚举两个字符串中的子字符串的起始位置,然后枚举长度。然后,使用STL中的substr函数提取两个字符串的子字符串。如果两个子串相等,比较前面的答案,选择较大的长度。让我们最终得到的最长公共子串是\(s\),那么答案就是\(|a| |b|-2\cdot|s|\)。

Code

字符串a,b;

int main(){ 0

MT {

CIN a;int len 1=a . size();CIN b;int len 2=b . size();

int ans=0;

F(int,I,0,len1 - 1) F(int,j,0,len2 - 1) F(int,k,0,len1 - i) F(int,l,0,len 2-j){ 0

if(k!=l)继续;//连长度都不一样。这两个子串肯定是不一样的。跳过。

字符串s1=a.substr(i,k),s2=b.substr(j,l);

if(s1==s2) ans=max(ans,(int)S1 . size());

}

println(len 1 len 2-ans * 2);

}

返回0;

}

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/147915.html

(0)

相关推荐

  • HBase默认配置是什么

    技术HBase默认配置是什么小编给大家分享一下HBase默认配置是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!hbase.rootdir

    攻略 2021年12月9日
  • 草木灰是什么,草木灰都有什么化学成分

    技术草木灰是什么,草木灰都有什么化学成分草木灰都有什么化学成分?要回答这个问题,得弄懂如下几个问题草木灰是什么。1、什么叫草木灰?2、草木灰的化学成分;3、草木灰的性质是什么?4、如何使用草木灰?
    一、什么叫草木灰?草木

    生活 2021年10月23日
  • vue自定义指令设置(vue自定义指令在什么场景使用)

    技术vue中自定义指令怎么用小编给大家分享一下vue中自定义指令怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、v-drag需求:鼠标拖动元素思路:元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始

    攻略 2021年12月16日
  • Python解释器种类以及特点是什么

    技术Python解释器种类以及特点是什么这篇文章将为大家详细讲解有关Python解释器种类以及特点是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python解释器是

    攻略 2021年12月4日
  • 十大名木手串,全球十大最名贵木材有哪些

    技术十大名木手串,全球十大最名贵木材有哪些感谢推荐十大名木手串!我个人是很喜欢盘玩木材的,尤其是小叶紫檀。最近迷上了桃木,因为桃木那独有的纹理是非常吸引我的。如下这些就是最世界珍贵的十种木材。一、乌木乌木(阴沉木)兼备木

    生活 2021年11月1日
  • java-异常-异常注意事项

    技术java-异常-异常注意事项 java-异常-异常注意事项1 package p1.exception;2 3 /*4 * 异常的注意事项:5 * 6 * 1,子类在覆盖父类方法时,父类的方法

    礼包 2021年11月5日