B. Catching Cheaters(最长公共子序列变形)

news2024/11/15 22:20:43

Problem - 1446B - Codeforces

 

给你两个字符串A和B,代表两个涉嫌作弊的学生的论文。对于任何两个字符串C,D,我们将其相似性分数S(C,D)定义为4⋅LCS(C,D)-|C|-|D|,其中LCS(C,D)表示字符串C和D的最长公共子序列。

你认为只有部分文章可能被复制了,因此你对它们的子串感兴趣。

计算所有子串对上的最大相似度分数。更正式地说,在所有对(C,D)上输出最大的S(C,D),其中C是A的某个子串,而D是B的某个子串。

如果X是一个字符串,|X|表示其长度。

如果一个字符串a可以通过从b中删除几个(可能是零个或全部)字符以及从结尾删除几个(可能是零个或全部)字符而得到,那么这个字符串就是一个字符串b的子串。

如果一个字符串a可以通过删除几个(可能是零个或全部)字符从b中得到,那么它就是一个字符串b的子序列。

请注意子串和子序列之间的区别,因为它们都出现在问题陈述中。

你可以阅读维基百科上关于最长公次问题的网页。

输入
第一行包含两个正整数n和m(1≤n,m≤5000)--两个字符串A和B的长度。

第二行包含一个由n个小写拉丁字母组成的字符串--字符串A。

第三行包含一个由m个小写拉丁字母组成的字符串--字符串B。

输出
在所有对(C,D)中输出最大的S(C,D),其中C是A的某个子串,D是B的某个子串。

例子
输入复制
4 5
abba
babab
输出拷贝
5
输入复制
8 10
bbbbabab
bbbabaaaaa
输出拷贝
12
输入副本
7 7
uiibwws
qhtkxcn
输出拷贝
0
注意
对于第一种情况。

第一个字符串的abb和第二个字符串的abab的LCS都等于abb。

结果是S(abb,abab)=(4⋅|abb|)-|abb|-|abab|=4⋅3-4=5。

题解:

说这到题前,我们先想想如何求两个字符串最长公共子序列

如下

for(int i = 1;i <= n;i++)
{
	for(int j = 1;j <= m;j++)
	{
		if(a[i] == b[j])
		{
			f[i][j] = f[i-1][j-1] +1; 
		}
		else
		{
			f[i][j] = max(f[i-1][j],f[i][j-1]);
		}
        ma = max(f[i][j],ma);
	}
}

但是这题加了一个条件,求最大得分 = 4*最长公共子序列长度 - 两个字符串长度

同样定义f[i][j]为a以i结尾,b以j结尾的最大得分

如果a[i] == b[j]

f[i][j] = f[i-1][j-1] + 2根据题意

关键是不等于的情况

f[i][j] = max(0,max(f[i-1][j],f[i][j-1])-1);

相当于是否要与状态f[i-1][j],f[i][j-1]接上来

如果小于等于0就断开

#include<iostream>
#include<algorithm>
#include<cstring>
#include<string>
#include<map>
#include<vector>
#include<queue>
using namespace std;
char a[5005];
char b[5005];
int f[5005][5005];
void solve()
{
	int n,m;
	cin >> n >> m;
	cin >>a+1>>b+1;

	int ma = 0;
	for(int i = 1;i <= n;i++)
	{
		for(int j = 1;j <= m;j++)
		{
			if(a[i] == b[j])
			{
				f[i][j] = f[i-1][j-1] + 2; 
			}
			else
			{
				f[i][j] = max(0,max(f[i-1][j],f[i][j-1])-1);
			}
			ma = max(f[i][j],ma);
		}
	}
	cout<<ma<<"\n";
}
int main()
{
	int t = 1;
//	cin >> t;
	while(t--)
	{
		solve();
	}
}
//1 4
//2 1
//2 4
//3 4


//1 2
//1 3
//2 3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/23167.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

三次握手与四次挥的问题,怎么回答?

在面试中&#xff0c;三次握手和四次挥手可以说是问的最频繁的一个知识点了&#xff0c;我相信大家也都看过很多关于三次握手与四次挥手的文章&#xff0c;今天的这篇文章&#xff0c;重点是围绕着面试&#xff0c;我们应该掌握哪些比较重要的点&#xff0c;哪些是比较被面试官…

大一学生网页课程作业 南京介绍网页设计 学生家乡网页设计作品静态 HTML网页模板源码 html我的家乡网页作业

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

uniapp自动识别并切换到pad端、pc端【不断更新】【伸手党福利】

目录uniapp自动切换到pad、pc端&#xff08;框架方法&#xff09;1. 新建文件&#xff1a;index为主页面&#xff08;代理页面&#xff09;detail为主页面的引用页面&#xff08;业务页面&#xff09;leftwindow为左边栏【名字随便起】topwindow为顶部栏【名字随便起】2. pages…

【LeetCode】808.分汤

题目描述 有 A 和 B 两种类型 的汤。一开始每种类型的汤有 n 毫升。有四种分配操作&#xff1a; 提供 100ml 的 汤A 和 0ml 的 汤B 。 提供 75ml 的 汤A 和 25ml 的 汤B 。 提供 50ml 的 汤A 和 50ml 的 汤B 。 提供 25ml 的 汤A 和 75ml 的 汤B 。 当我们把汤分配给某人之后&a…

【selenium】多 frame 切换定位元素

frame 简介 frame 是 html 中的框架导航。同一个框架集中&#xff0c;点击某一框架的超链接&#xff0c;内容会在另一个框架的窗口中展示。 比如后台管理页面&#xff0c;点击左侧导航栏按钮&#xff0c;在右侧区域展示加载的内容&#xff0c;而不是打开一个新的窗口。 fram…

【node进阶】在node.js中优雅的使用Socket.IO模块

✅ 作者简介&#xff1a;一名普通本科大三的学生&#xff0c;致力于提高前端开发能力 ✨ 个人主页&#xff1a;前端小白在前进的主页 &#x1f525; 系列专栏 &#xff1a; node.js学习专栏 ⭐️ 个人社区 : 个人交流社区 &#x1f340; 学习格言: ☀️ 打不倒你的会使你更强&a…

Serverless Devs 重大更新,基于 Serverless 架构的 CI/CD 框架:Serverless-cd

近日&#xff0c;Serverless 开发者平台 Serverless Devs 重磅发布基于 Serverless 架构的轻量级 CI/CD 框架——Serverless-cd。Serverless-cd 是一款运行在 Serverless 架构上的功能强大而灵活&#xff0c;安全&#xff0c;低成本的CI/CD开源框架。该框架基于 Serverless Dev…

ML XGBoost详细原理及公式推导讲解+面试必考知识点

&#x1f604; 搞竞赛天天无脑XGBoost、LightGBM、CatBoost&#xff0c;但不知道原理也少许有点尴尬了~&#xff0c;所以打算深入学习下这三大竞赛杀器的原理&#xff0c;整理下面试中一些高频问题。之前有决策树&#xff0c;GBDT的基础了&#xff0c;再学学这三个和随机森林&a…

unix网络编程(四)epoll反应堆

epoll反应堆原理代码demo原理 【epoll模型原来的流程】&#xff1a; epoll_create(); // 创建监听红黑树 epoll_ctl(); // 向书上添加监听fd epoll_wait(); // 监听 有监听fd事件发送—>返回监听满足数组—>判断返回数组元素—> lfd满足accept—>返回cfd---->r…

【仿牛客网笔记】项目进阶,构建安全高效的企业服务——任务执行和调度

http://www.quartz-scheduler.org 集群服务器有两类程序一类普通请求&#xff0c;另一类定时任务。 浏览器通过负载均衡工具Nginx, Nginx同一时刻有一个去处理。 Quartz存入到数据库中&#xff0c;多个Quartz同时访问 线程池测试类 实例化logger,通过logger输出&#xff0c;自…

Java学习之封装

**学习重点&#xff1a;**面向对象编程的三大特征&#xff1a;封装、继承、多态度 封装介绍 封装&#xff1a;encapsulation就是把属性和方法封装在一起&#xff0c;数据被保护在内部&#xff0c;程序的其它部分只有通过被授权的操作&#xff08;方法&#xff09;&#xff0c…

【Linux】四、Linux 进程概念(二)|普遍操作系统的进程状态(运行、阻塞、挂起)|Linux的具体进程状态|僵尸进程|孤儿进程

目录 五、进程状态 5.1 普遍操作系统层面的进程状态&#xff08;宏观&#xff09; 5.1.1 什么叫做运行状态 5.1.2 阻塞状态 5.1.2 挂起状态 5.2 Linux 的进程状态&#xff08;具体&#xff09; 5.2.1 Linux 内核进程状态源代码 5.2.2 Linux 进程状态查看 5.2.3 Linux …

2023年软考高级系统规划与与管理师备考策略

2023年上半年软考高级系统规划与管理师打算怎么备考呢&#xff1f; 系统规划与管理师是高级科目的其中一科&#xff0c;难度系数是有的&#xff0c;系统规划与管理师相较于其他高级考试又相对难度可控。只要你肯下功夫&#xff0c;还是可以拿下的&#xff01;系统规划与管理师…

ASP.NET Core教程-Routing(路由)

更新记录 转载请注明出处&#xff1a; 2022年11月21日 发布。 2022年11月20日 从笔记迁移到博客。 Route Basic(路由基础) 路由说明 请求URL映射到控制器方法的过程&#xff0c;这个映射过程由路由规则定义。 路由功能 跟据预先配置的路由信息对客户端传来的请求进行路由映射&a…

Hbase Coprocessor 协处理器 与 JavaAPI

协处理器概念 一、协处理器有两种&#xff1a; observer 和 endpoint 1、observer协处理器 Observer 类似于传统数据库中的触发器&#xff0c;当发生某些事件的时候这类协处理器会被 Server 端调用。Observer Coprocessor 就是一些散布在 HBase Server 端代码中的 hook 钩子…

go使用grpc

protoc下载 protoc是protobuf的编译工具&#xff0c;能根据.proto文件生成为各种语言的文件。 原始的protoc集成了如下语言的转换&#xff1a; cc#javaobjectcphppythonruby 但是没有集成go的转换工具。go的转换工具是在protoc的基础上使用插件的方式运行。 protoc 的下载地址…

java面试强基(7)

hashCode() 有什么用&#xff1f; ​ hashCode() 的作用是获取哈希码&#xff08;int 整数&#xff09;&#xff0c;也称为散列码。这个哈希码的作用是确定该对象在哈希表中的索引位置。 ​ hashCode()定义在 JDK 的 Object 类中&#xff0c;这就意味着 Java 中的任何类都包含…

阿里架构师耗时1年,把P8所需要的整个Java体系,都整理到了一起

始末 有人调侃我们说&#xff1a; 程序员不如送外卖。送外卖是搬运食物&#xff0c;自己是搬运代码&#xff0c;都不产出新的东西……透支体力&#xff0c;又消耗健康&#xff0c;可替代性极强&#xff0c;30岁之后就要面临被优化的危险……想跳槽&#xff0c;但是更高的平台…

科技风杂志科技风杂志社科技风编辑部2022年第31期目录

科技创新《科技风》投稿&#xff1a;cnqikantg126.com 基于钢架网箱清理控制系统的研究 张浩;崔新忠;丁树兵;尹杰;卢佳乐;王隽屹;张津宁; 1-3 遥感技术在海洋区域地质调查中的应用——以岛礁区调查为例 韩艳飞; 4-6 医院电气工程智能自动化及PLC技术在医院电气设备…

mipi介绍

文章目录1.MIPI简介1-1&#xff1a;DSI layer2.D_PHY2-1&#xff1a;D_PHY介绍2-2&#xff1a;电平状态2-3&#xff1a;lane结构2-4&#xff1a;data lane操作模式2-4-1&#xff1a;escape mode和space one hot coding2-4-2&#xff1a;Low-Power Data Transmission&#xff08…