PAT A1030 动态规划

news/2024/7/6 4:50:55 标签: 数据结构与算法

clipboard.png
这道题是动态规划几大问题的其中一种,为最长回文子串问题;

动态规划个人来说,觉得最重要的就是建立状态转移方程。对于方程变量,我认为最重要的是有几个构成的关键变量;

对于这道题,我们着手于i~j个字符,所以关注点在于i和j,所以我们建立一个二维矩阵来保存动态规划途中的计算值。对于dpi,其值为1时,意为i-j的字串是回文子串,为其他值则不是;

对于状态转移方程,我们可以这样想:对于一个回文子串,其子串也是回文子串,所以就有方程转移的定律:
dpi=dpi+1

接下来就是如何遍历;
对于遍历,我们一定要保证从边界开始,并且现有计算状态必须建立在已有建立状态之上。由于转换方程的特殊性,i,j两个坐标都像两边扩散,所以我们可以根据L,也就是子串的长度来进行计算;
先将单个字符相应的值置为1,然后L=2.....至L=n;在途中记录子串的长度;

代码如下所示:

#include<iostream>
#include<stdlib.h>
#include<stdio.h>
#include<cstring>
#include<string>
using namespace std;
const int maxn=1010;
string data;
int matrix[maxn][maxn];
int main(){
    getline(cin,data);
    int len=data.size();
    for(int i=0;i<len;i++){
        matrix[i][i]=1;
    }
    int ans=1;
    for(int i=1;i<len;i++){
        if(data[i-1]==data[i]){
            matrix[i-1][i]=1;
            ans=2;
        }
    }
    for(int L=3;L<=len;L++){
        for(int i=0;i+L-1<len;i++){
            int j=i+L-1;
            if(data[i]==data[j]&&matrix[i+1][j-1]==1){
                matrix[i][j]=1;
                ans=L;
            }
        }
    }
    printf("%d\n",ans);
    system("pause");
    return 0;
}

http://www.niftyadmin.cn/n/1573801.html

相关文章

决策需要数据,数据需要分析,分析需要决策

生活无时不刻需要决策&#xff0c;决策需要数据来驱动&#xff0c;如何驱动&#xff0c;需要分析来帮忙&#xff0c;然而最具戏剧性的是&#xff1a;分析也是有策略的——分析也需要决策。 例子 举个例子&#xff0c;随着年龄的增长&#xff0c;见识了越来越的年轻人由于不看…

数据 信息 知识 智慧

数据信息知识智慧原始的数字和事实经过处理的数据可发挥作用的信息 反应事物运动状态的原始数字和事实已经排列成有意义的形式的数据已经加工提炼,将很多信息材料的内在联系进行综合分析,从而得出的系统结论激活了的知识,主要表现为收集、加工、应用、传播信息和知识的能力,…

Java排序算法之插入排序

插入排序是简单排序中最快的排序算法&#xff0c;虽然时间复杂度仍然为O(n*n)&#xff0c;但是却比冒泡排序和选择排序快很多。 一、原理 1、将指针指向某个元素&#xff0c;假设该元素左侧的元素全部有序&#xff0c;将该元素抽取出来&#xff0c;然后按照从右往左的顺序分别与…

培养数据意识的正确态度

要多与人沟通&#xff0c;不要偏执&#xff0c;在相信数据之前&#xff0c;要有勇气否定自己的一些经验和想法&#xff0c;做到时常关注数据&#xff0c;多思考数据背后的东西。 现在互联网衍生出很多新的玩法和新的事物&#xff0c;已经远超出了我们过去的认知&#xff0c;不要…

Nodejs操作Cassandra数据库

目录 前言安装CassandraNodejs操作Cassandra前言 操作系统win10时间2019年02月Nodejs版本&#xff1a;node v8.9.3Cassandra版本&#xff1a;cassandra-3.11.3参考网址1安装Cassandra 安装Cassandra数据库 官网下载Cassandra压缩包解压&#xff0c;并配置环境变量&#xff1a;操…

数据库建模

什么是数据建模&#xff1f; 就是将现实世界的“事物”和“事物之间的关系”经过抽象、概括&#xff0c;转化为数据仓库中表的过程。 数据建模的本质&#xff1a;眼里只有两张表 那么如何转化呢&#xff1f;只要在进行抽象和概括时&#xff0c;牢记&#xff1a;我们的眼里只有…

win32.udiskvir.spath.b病毒处理

杀毒软件发现svchost.exe病毒&#xff0c;病毒目录是c:\windows\temp&#xff0c;这个文件是仿系统进程&#xff0c;可通过tasklist.exe /svc &#xff5c;findstr “svchost.exe”查找描述列为“暂缺”的&#xff0c;记住pid。 通过任务管理器中止不起作用&#xff0c;删除病毒…

springboot借助aop和注解轻松实现权限安全校验

我们用springboot做后台开发&#xff0c;难免会用到权限校验&#xff0c;比如查看当前用户是否合法&#xff0c;是否是管理员。而spring的面向切面的特效可以帮助我们很好的实现动态的权限校验。这里我们就用到的spring的aop。接下来就带领大家用aop和注解来快速的实现权限校验…