psd面试(最长回文子序列+动态规划);

2024-09-05 21:38

本文主要是介绍psd面试(最长回文子序列+动态规划);,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点击打开链接

链接:https://www.nowcoder.com/acm/contest/90/D
来源:牛客网

题目描述

掌握未来命运的女神 psd 师兄在拿了朝田诗乃的 buff 后决定去实习。
埃森哲公司注册成立于爱尔兰,是一家全球领先的专业服务公司,为客户提供战略、咨询、数字、技术和运营服务及解决方案。他们立足商业与技术的前沿,业务涵盖40多个行业,以及企业日常运营部门的各个职能。凭借独特的业内经验与专业技能,以及翘楚全球的交付网络,他们帮助客户提升绩效,并为利益相关方持续创造价值。埃森哲是《财富》全球500强企业之一,目前拥有约41.1万名员工,服务于120多个国家的客户。于是psd打算去埃森哲公司投一下简历。
于是他用英文写了一篇简历,由于手速太快了以致自己都不知道写了什么。
然而面试官 xwc 一眼就看到了重点:大学打过 ACM!
xwc:“
    听说你很低袄?考你个题:
    忽略字母大小写,你这篇简历去掉最长的回文子序列后还有多长?

psd 顺手就把这个问题抛给了你。

输入描述:

多组输入,每组输入一个长度不超过 1234 的没空格的字符串,是 psd 的简历。

输出描述:

每组输出一个整数,如题。

子问题:从i为头以j为尾的子串中最长回文子序列的长度是多少;

由子问题可得状态dp[i][j]是以i为头以j为尾的子串中最长回文子序列的长度是多少;

状态转移方程:有两个决策:

1:当该子串首尾相同时,该子串的最长回文子序列的长度可由该子串不包括首尾的最长子串的最长回文子序列长度转移过来;即dp[i][j]=dp[i+1][j-1]+2;

2:当该子串的首尾不同时,该子串的最长回文子序列的长度可由该子串的最长子串(不包括该子串本身)的最长回文子序列转移过来;因为该子串的最长子串(不包括该子串本身)有两个,所以状态转移方程为 dp[i][j]=max(dp[i][j-1],dp[i+1][j]);

注意:因为dp[i][j]必须从dp[i+1][j-1]或dp[i+1][j-1]或dp[i][j-1]转移过来,所以状态dp[i+1][j-1],dp[i+1][j-1],dp[i][j-1]必须在dp[i][j]前面;所以i是递减的,j是递增的。又由i,j含义可得i<j;

代码如下

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
/*
google
输出2
示例2
输入aBc,bAd
输出2
*/
const int INF = 1240;int LongestPalindromeSubsequence(char* str,int len);void Preprocessing(char* str,int len) ;int dp[INF][INF];int main()
{char data[INF] ;while(~scanf("%s",data)){int length = strlen(data);Preprocessing(data,length);             				//预处理,使字符串统一为小写字母 int result = LongestPalindromeSubsequence(data,length);  //最长回文子序列 printf("%d\n",length-result);}return 0;
}
int LongestPalindromeSubsequence(char* str,int len)
{memset(dp,0,sizeof(dp));for(int i = len-1;i >= 0;i--){dp[i][i]=1;for(int j = i+1;j < len;j++){if(str[i] == str[j]){dp[i][j] = dp[i+1][j-1] += 2;}else{dp[i][j] = max(dp[i+1][j],dp[i][j-1]);}} }return dp[0][len-1];
}
void Preprocessing(char* str,int len) 
{for(int i = 0;i < len;i++){if(str[i] >= 'A' && str[i] <= 'Z')str[i] += 32;}
}


这篇关于psd面试(最长回文子序列+动态规划);的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140136

相关文章

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计