L3-020 至多删三个字符 [DP]

这题在网上看到一个非常容易理解的思路,和大家分享一下。

记dp[i][j]为前i个字符删除j个字符后得到不同字符串的数量,可以得到以下两个转移方程

dp[i][j+1]=dp[i][j+1]+dp[i-1][j] (删除s[i])

dp[i][j]=dp[i][j]+dp[i-1][j] (不删除s[i])

 如果只用上述式子,是会重复的。比如abcdecf,删除cde得到abcf,删除dec得到的也是abcf。

所以要删除重复计算的。从当前的i向左扫,扫到的第一个与s[i]相同的字符时处理,假设为s[k],那么dp[i][j]=dp[i][j]-dp[k-1][j-(i-k)]。

#include<iostream>
#include<cstdio>
#include<string.h>
#include<math.h>
#define maxn 1000005
using namespace std;
typedef long long ll;
char s[maxn];
ll dp[maxn][5];
int main()
{scanf("%s",s+1);int l=strlen(s+1);dp[0][0]=1;for(int i=0;i<=l;i++){for(int j=0;j<=3;j++){if(dp[i-1][j]==0)continue;if(j<3)dp[i][j+1]+=dp[i-1][j];dp[i][j]+=dp[i-1][j];for(int k=i-1;k>=1&&i-k<=j;k--){if(s[k]==s[i]){dp[i][j]-=dp[k-1][j-i+k];break;//如果有多个,因为是从前往后推的,所以在前面减过了
                }}}}printf("%lld\n",dp[l][0]+dp[l][1]+dp[l][2]+dp[l][3]);return 0;
}
View Code

 

转载于:https://www.cnblogs.com/FTA-Macro/p/10472057.html

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

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

相关文章

idea中使用osgi_OSGi中的权限

idea中使用osgi在上一篇文章中 &#xff0c;我们介绍了为Java应用程序实现沙箱的方法&#xff0c;在其中我们可以安全地运行移动代码 。 这篇文章探讨了如何在OSGi环境中执行相同的操作。 OSGi OSGi规范 为Java定义了一个动态模块系统 。 因此&#xff0c;它是实施那种可以使…

我的世界末日之后无限法则服务器,《我的世界》全新玩法无限法则上线

完整细致的世界体系&#xff0c;丰富多样的地图&#xff0c;拥有无限探索可能的新世界欢迎你的到来。春节期间&#xff0c;《我的世界》手游全新玩法《无限法则》重磅上线&#xff0c;带大家一同体验无限创造的魅力。冒险家们&#xff0c;一起开启新世界的冒险之旅吧&#xff0…

python风流史

python的创始人为吉多范罗苏姆&#xff08;Guido van Rossum&#xff09;。1989年的圣诞节期间&#xff0c;吉多范罗苏姆&#xff08;中文名字&#xff1a;龟叔&#xff09;为了在阿姆斯特丹打发时间&#xff0c;决心开发一个新的脚本解释程序&#xff0c;作为ABC语言的一种继承…

将Infinispan版本映射为最低Java版本

我最近一直在与Infinispan交流 &#xff0c;我注意到这种“分布式内存键/值数据存储”的特征之一是它相对积极地采用&#xff0c;甚至要求更高版本的Java。 根据参考的Infinispan文档 &#xff0c;以下内容将Infinispan版本映射到最低必需的Java SE版本。 Infinispan版本及其…

python 在不同层级目录import 模块的方法

http://www.cnitblog.com/seeyeah/archive/2009/03/15/55440.html Python包含子目录中的模块方法比较简单&#xff0c;关键是能够在sys.path里面找到通向模块文件的路径。 下面将具体介绍几种常用情况: &#xff08;1&#xff09;主程序与模块程序在同一目录下: 如下面程序结构…

vue-resource ajax跨域,基于Vue-resource jsonp跨域问题的解决方法_婳祎_前端开发者

最近在学习关于什么是jsonp&#xff0c;以及为什么要用jsonp我就不多说了&#xff0c;不明白的同学自行百度一下。我们先来说一下这里我以json数据为例&#xff0c;首先我们通过 $.get可以直接得到一个我们想要的对象&#xff0c;但是用 jsonp 就会出现报错代码如下&#xff0c…

Kali Linux 2016.2初体验

前言 Kali Linux官方于8月30日发布Kali Linux 2016的第二个版本Kali Linux 2016.2。该版本距离Kali Linux 2016.1版本发布&#xff0c;已经有7个月。在这期间&#xff0c;在Kali Linux 2016.2版本发布的这段时间&#xff0c;Kali Linux官方增补了94个更新。 主要的更新大概是这…

ajax servlet增删改查,Servlet ajax 文件上传和JDBC+Servler用户表增删改查

昨天晚上帮一个妹子&#xff0c;应该是大二或者大三的。解决了ServletJDBC实现用户表的增删改查功能&#xff0c;当时妹子遇到的问题是文件上传和日期格式处理不太会。我让她把代码发我&#xff0c;我本地调试&#xff0c;结果发现坑很多&#xff0c;就是很多细节问题。不过对于…

1065 单身狗

“单身狗”是中文对于单身人士的一种爱称。本题请你从上万人的大型派对中找出落单的客人&#xff0c;以便给予特殊关爱。 输入格式&#xff1a; 输入第一行给出一个正整数 N&#xff08;≤ 50 000&#xff09;&#xff0c;是已知夫妻/伴侣的对数&#xff1b;随后 N 行&#xff…

不,保持警惕不会伤害Java。 关于Java许可的评论。

所以。 Oracle希望通过Java赚钱。 然后&#xff0c;The Register发表了一篇非常对立的文章&#xff0c;上面有一个超级吸引人的标题。 根据他们的消息来源&#xff0c;“ Oracle正在大力加强对其声称违反其许可证的Java客户的审计”。 当Twitter诗句对人们批评甲骨文的行为持批…

移动端ajax,jQuery基于$.ajax设置移动端click超时处理方法

本文实例讲述了jQuery基于$.ajax设置移动端click超时处理方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;这里介绍jquery click事件如何在移动端自动转换成touchstart事件。因为移动端click事件会比touchstart事件慢几拍移动设备某个元素上事件执行顺序是&#xf…

Python单例模式的4种实现方法

[python] view plaincopy #-*- encodingutf-8 -*- print ----------------------方法1-------------------------- #方法1,实现__new__方法 #并在将一个类的实例绑定到类变量_instance上, #如果cls._instance为None说明该类还没有实例化过,实例化该类,并返回 #如果cl…

java虚拟机-程序计数器PC Register

什么是程序计数器&#xff1f; 程序计数器是一块 较小 的内存空间&#xff0c;它可以看做是当前线程所执行的字节码的 行号指示器 &#xff1b;在虚拟机的概念模型里&#xff08;仅仅是概念模型&#xff0c;各种虚拟机可能会通过一些更高效的方式去实现&#xff09;&#xff0c…

织梦ajax表单提交参数错误,【织梦二次开发】织梦jquery+ajax方式提交自定义表单...

我们在dedecms教程中学到很多&#xff0c;比如可以借助jquery ajax提交dedecms自定义表单到后台。此例只做为参考&#xff0c;实际项目中根据自己的情况酌情修改。html部分&#xff1a;姓名&#xff1a;电话&#xff1a;留言&#xff1a;js部分&#xff1a;function send(){$.a…

R-Tree空间索引算法的研究历程和最新进展分析

摘要&#xff1a;本文介绍了空间索引的概念、R-Tree数据结构和R-Tree空间索引的算法描述&#xff0c;并从R-Tree索引技术的优缺点对R-Tree的改进结构——变种R-Tree进行了论述。最后&#xff0c;对R-Tree的最新研究进展进行了分析。 关键词&#xff1a;空间索引技术&#xff1b…

Git同时使用不同平台代码仓库

问题描述 公司项目使用代码仓库为gitinn/gitlab等&#xff0c;个人项目使用github进行托管&#xff0c;而公司项目和个人项目设置的邮箱和用户名是不同的&#xff0c;而ssh的密钥对又是基于这两个信息生成的&#xff0c;所以此时想要同时使用两个平台的代码仓库&#xff0c;则会…

java签署ssl_签署Java代码

java签署ssl在上一篇文章中&#xff0c;我们讨论了如何保护移动代码 。 提到的措施之一是签名代码。 这篇文章探讨了Java程序如何工作。 数字签名 数字签名的基础是密码学 &#xff0c;特别是公钥密码学 。 我们使用一组加密密钥&#xff1a;私有密钥和公共密钥。 私钥用于…

服务器中有两个R文件夹,一台服务器中配置多个git sshkey

需求背景&#xff1a;GitHub上有两个项目&#xff0c;需要拉取到同一台服务器&#xff0c;并且都需要通过ssh的方式拉取假设两个项目分别叫&#xff1a; proj1 和 proj2一、分别生成 ssh key# 先生成 proj1 的 sshkey$ ssh-keygen -t rsa -C "888888qq.com"image.png…

1-26HashSet简介

Set的特点 Set里面存储的元素不能重复&#xff0c;没有索引&#xff0c;存取顺序不一致。 package com.monkey1024.set;import java.util.HashSet;/*** Set的特点&#xff1a;元素不能重复&#xff0c;没有索引&#xff0c;存取顺序不一致**/ public class HashSetTest01 {publ…

C++ 异常 与 ”为什么析构函数不能抛出异常“ 问题

C 用异常使得可以将正常执行代码和出错处理区别开来。 比如一个栈&#xff0c;其为空时&#xff0c;调用其一个pop 函数&#xff0c;接下来怎么办&#xff1f; 栈本身并不知道该如何处理&#xff0c;需要通知给其调用者&#xff08;caller&#xff09;&#xff0c;因为只有调用…