牛客竞赛每日俩题 - 动态规划2

news2024/10/6 12:32:22

目录

经典DP - 走方格

        走方格2.0

分割回文串

        分割回文串 - 回文优化


经典DP - 走方格

不同路径的数目(一)_牛客题霸_牛客网

状态:
        子状态:从(0,0) 到达 (1,0),(1,1),(2,1),...(m-1,n-1) 的路径数
        F(i,j): 从 (0,0) 到达 F(i,j) 的路径数
状态递推:
        F(i,j) = F(i-1,j) + F(i,j-1)
初始化:
        特殊情况:第0 行和第 0
        F(0,i) = 1
        F(i,0) = 1
返回结果:
        F(m-1,n-1)

class Solution {
public:

    int uniquePaths(int m, int n) {
        if(m<1||n<1) return 0;

        vector<vector<int>> ret(m,vector<int>(n,1));

        for(int i=1;i<m;i++)
            for(int j=1;j<n;j++) 
                ret[i][j]=ret[i-1][j]+ret[i][j-1];
        return ret[m-1][n-1];
    }
};

走方格2.0

带权值的最小路径和_牛客题霸_牛客网

状态:
        子状态:从(0,0) 到达 (1,0),(1,1),(2,1),...(m-1,n-1) 的最短路径
        F(i,j): 从 (0,0) 到达 F(i,j) 的最短路径
状态递推:
        F(i,j) = min{F(i-1,j) , F(i,j-1)} + (i,j)
初始化:
        F(0,0) = (0,0)
        特殊情况:第0 行和第 0
        F(0,i) = F(0,i-1) + (0,i)
        F(i,0) = F(i-1,0) + (i,0)
返回结果:
        F(m-1,n-1)

class Solution {
public:

    int minPathSum(vector<vector<int> >& grid) {
        if(grid.empty()||grid[0].empty()) return 0;

        int m=grid.size();
        int n=grid[0].size();
        vector<vector<int>> ret(m,vector<int>(n,0));

        ret[0][0]=grid[0][0];
        for(int i=1;i!=m;i++) ret[i][0]=ret[i-1][0]+grid[i][0];
        for(int i=1;i!=n;i++) ret[0][i]=ret[0][i-1]+grid[0][i];

        for(int i=1;i<m;i++)
            for(int j=1;j<n;j++){
                ret[i][j]=min(ret[i-1][j],ret[i][j-1])+grid[i][j];
            }
        return ret[m-1][n-1];
    }
};

分割回文串

分割回文串-ii_牛客题霸_牛客网

状态:
        子状态:到第1,2,3,...,n 个字符需要的最小分割数
        F(i): 到第 i个字符需要的最小分割数
状态递推:
        F(i) = min{F(i), 1 + F(j)}, 当 j<i && j+1到 i 是回文串 时
        上式表示如果从j+1 i 判断为回文字符串,且已经知道从第 1 个字符
        到第j 个字符的最小切割数,那么只需要再切一次,就可以保证
        1-->j, j+1-->i都为回文串。
初始化:
        F(i) = i - 1
        上式表示到第i 个字符需要的最大分割数
        比如单个字符只需要切0 次,因为单子符都为回文串
        2个字符最大需要 1 次, 3 2 ......
返回结果:
        F(n)

举个栗子: 对于字符串"aabaa",对于当 j<i && j+1到i是回文串才更新的情况

f[0]=-1;则字符串“a”有min(f[1],1+f[0])==0;

对字符串“aa”有min(f[2],1+f[0])==min(1,0)==0;

对字符串“aab”有min(f[3],1+f[1])==min(2,1)==1;

对字符串“aaba”有min(f[4],1+f[1])==min(3,1)==1;(a|aba)

.......

沿途会遍历所有分割方法,取最小值

class Solution {
  public:
    int minCut(string s) {
        if (s.empty()) return 0;
        int len = s.size();
        vector<int> cut;
        // F(i)初始化
        // F(0)= -1,必要项,如果没有这一项,对于重叠字符串“aaaaa”会产生错误的结果
        for (int i = 0; i < 1 + len; ++i) {
            cut.push_back(i - 1);
            //最大分割数随字符增加
        }
        for (int i = 1; i < 1 + len; ++i) {
            for (int j = 0; j < i; ++j) {
                // F(i) = min{F(i), 1 + F(j)}, 当 j<i && j+1到i是回文串才更新
                if (isPalindrome(s, j, i - 1)) {
                    cut[i] = min(cut[i], 1 + cut[j]);
                }
            }
        }
        return cut[len];
    }
    //判断是否回文串
    bool isPalindrome(string s, int i, int j) {
        while (i < j) {
            if (s[i] != s[j]) {
                return false;
            }
            i++;
            j--;
        }
        return true;
    }
};
上述方法两次循环时间复杂度是 O(n^2),
判断回文串时间复杂度是 O(n),
所以总时间复杂度为 O(n^3)
对于过长的字符串,在 OJ 的时候会出现 TLE(Time Limit Exceeded)

 分割回文串 - 回文优化

状态:
        从第一个字符到第二个字符是不是回文串,第1-3 ,第 2-5 ...
        F(i,j): 字符区间 [i,j] 是否为回文串
状态递推:
        F(i,j): true->{s[i]==s[j] && F(i+1,j-1)} 否则false
        上式表示如果字符区间首尾字符相同且在去掉区间首尾字符后字符区间仍为回文串
        则原字符区间为回文串
        从递推公式中可以看到第i 处需要用到第 i+1 处的信息,所以 i 应该从字符串末尾遍历
初始化:
        F(i,j) = false
返回结果:
        矩阵F(n,n), 只更新一半值( i <= j), n^2 / 2

举个栗子:

我们看递推公式发现 true->{s[i]==s[j] && F(i+1,j-1)}更新所需要的状态是下一行的前一列,也就是说要从下往上更新

for (int i = len - 1; i >= 0; --i) {//从最后一行开始更新
    for (int j = i; j < len; ++j) {
        if (j == i) {
        // 一个字符
            mat[i][j] = true;
        } 
        else if (j == i + 1) {
        // 只有两个
            mat[i][j] = (s[i] == s[j]);
        } 
        else {
            mat[i][j] = ((s[i] == s[j]) && mat[i + 1][j - 1]);
        }
    }

class Solution {
  public:
    int minCut(string s) {
        if (s.empty()) return 0;
        int len = s.size();
        vector<int> cut;
        for (int i = 0; i < 1 + len; ++i) {
            cut.push_back(i - 1);
        }

        vector<vector<bool> > mat = getMat(s);//dp回文串

        for (int i = 1; i < 1 + len; ++i) {
            for (int j = 0; j < i; ++j) {
                if (mat[j][i - 1]) {
                    cut[i] = min(cut[i], 1 + cut[j]);
                }
            }
        }
        return cut[len];
    }
    vector<vector<bool> > getMat(string s) {
        int len = s.size();
        vector<vector<bool> > mat = vector<vector<bool> >(len, vector<bool>(len,
                                    false));
        for (int i = len - 1; i >= 0; --i) {
            for (int j = i; j < len; ++j) {
                if (j == i) mat[i][j] = true;
                else if (j == i + 1) mat[i][j] = (s[i] == s[j]);
                else mat[i][j] = ((s[i] == s[j]) && mat[i + 1][j - 1]);
                
            }
        }
        return mat;
    }
};

判断回文串的方法可以继续优化,使总体时间复杂度将为O(n^2) 

 

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

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

相关文章

【23届秋招总结系列】一个普本23届小学弟的秋招总结,上岸金山云开发(云计算方向)

大家好&#xff0c;我是路飞~ 正值秋招收尾阶段&#xff0c;今天很荣幸请来了交流qun小分队里的一位23届本科上岸 金山云开发工程师-云计算方向的同学&#xff0c;给大家分享一下他在秋招过程中的总结和心得体会。 他的博客链接&#xff1a;团子的守护 一、秋招收获 2022.1…

计算机毕业设计SSM大学生创新创业项目活动管理平台【附源码数据库】

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【微服务】Nacos服务发现源码分析

&#x1f496;Spring家族及微服务系列文章 ✨【微服务】SpringBoot监听器机制以及在Nacos中的应用 ✨【微服务】Nacos服务端完成微服务注册以及健康检查流程 ✨【微服务】Nacos客户端微服务注册原理流程 ✨【微服务】SpringCloud中使用Ribbon实现负载均衡的原理 ✨【微服务】Sp…

Ubuntu20.04安装k8s v1.21.0

1. 禁用swap分区, 修改网络配置 sudo vim /etc/fstab 把有swap的那一行注释掉即可&#xff0c;如下&#xff1a; 然后执行如下命令 cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf net.bridge.bridge-nf-call-ip6tables 1 net.bridge.bridge-nf-call-iptables 1 EOF …

12.帖子模块——使用peewee创建多表关联的结构,使用Tornado创建查询接口、增加接口

1.模型建立与数据初始化 1.1分析建立表所需要的字段 本次主要是添加一个帖子展示时&#xff0c;所需要的内容&#xff0c;这里就得创建一个mysql的数据表去存储它的内容。 1.2 使用peewee创建多表关联结构Model 模型建立 # forum/models.py # 用于创建数据表模型from peewe…

企业自研业务系统的登录如何添加动态口令,实施MFA双因子认证?

一、背景需求 不少企业因业务需要会自己研发业务系统&#xff0c;为保护业务数据安全&#xff0c;首先要确保能访问到业务数据的人员“身份”安全可信。 企业自研业务系统的账号密码基本是 IT 管理员单独管理维护&#xff0c;员工为了方便记忆&#xff0c;通常设置与其他商采系…

函数绘图仪 MathGrafix 12.1 Crack

函数绘图仪 MathGrafix 12.1 MatheGrafix 12.1于 2022 年 8 月 1 日发布&#xff0c;包含两个新模块&#xff1a; 公式函数模块支持具有一个变量和最多十个参数的函数方程。每个参数都可以使用自动运行的滑块进行调整。 在数据模块中&#xff0c;记录数据后&#xff0c;使用回…

网页制作基础大二dw作业HTML+CSS+JavaScript云南我的家乡旅游景点

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

【C++笔试强训】第二十一天

&#x1f387;C笔试强训 博客主页&#xff1a;一起去看日落吗分享博主的C刷题日常&#xff0c;大家一起学习博主的能力有限&#xff0c;出现错误希望大家不吝赐教分享给大家一句我很喜欢的话&#xff1a;夜色难免微凉&#xff0c;前方必有曙光 &#x1f31e;。 &#x1f4a6;&a…

装饰模式与职责链模式笔记

装饰模式&#xff08;Decorator&#xff09; 概念 动态地给一个对象添加一些额外的职责&#xff0c;就增加功能来说&#xff0c;装饰模式比生成子类更为灵活。UML类图&#xff1a; 代码 给人打扮 //人类(ConcreteComponent) public class Person {private String name;public…

[附源码]java毕业设计ssm实验教学资源管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

C语言笔记第03章:数组

了解更多关注中南林业科技大学软件协会官网&#xff1a;https://www.csuftsap.cn/ 来自软件协会编辑&#xff0c;注册会员即可获取全部开源.md资源&#xff0c;请勿转载&#xff0c;归软件协会所有。 任何问题联系软件协会。 文章目录:star: 数组1.八个老婆引出数组 - 为什么…

1.7.2、计算机网络体系结构分层的必要性

1.7.2、计算机网络体系结构分层的必要性 计算机网络是个非常复杂的系统\color{red}计算机网络是个非常复杂的系统计算机网络是个非常复杂的系统。早在最初的ARPANET设计时就提出了分层的设计理念。 "分层\color{red}分层分层"可将庞大而复杂的问题&#xff0c;转化为…

一专多能、创新力十足,南大通用GBase8c数据库获鲲鹏创新应用大赛金奖

被评为openGauss赛道金奖的多模多态分布式数据库GBase 8c其含金量表现在哪些方面&#xff1f;基于openGauss有哪些技术创新&#xff1f; 其商业价值是什么&#xff1f;在哪些场景发挥作用&#xff1f; 面向全球开发者的年度顶级赛事——鲲鹏应用创新大赛已经举办三个年头了。三…

DHCP协议从入门到部署DHCP服务器进行实验

目录 1、DHCP基本概念 2、DHCP的优点 3、DHCP的工作原理 4、通过抓包验证原理 5、在windows server上部署DHCP服务器 6、实验搭建 实验环境 配置R1的中继 常见报文学习 1、DHCP基本概念 路由器可以阻挡DHCP discover的广播报文 2、DHCP的优点 3、DHCP的工作原理 4、通过抓…

Java笔试复盘

目录 1. finalize的含义 2.Statement和PreparedStatement用法 3. 接口能用protected修饰吗 4.java实现分解质因数 今天去参加了一场国企单位的笔试&#xff0c;很基础&#xff0c;但是有些细节的地方还是觉得答得不好&#xff0c;所以复盘一下。 1. finalize的含义 final…

WPF几何绘图(2)

Path的各种线段&#xff1a; LineSegment 直线段。 ArcSegment 圆弧线段。 BezierSegment 三次贝塞尔曲线段&#xff08;默认贝斯尔曲线是指三次曲线&#xff09;。 QuadraticBezierSegment 二次贝塞尔曲线段。 PolyLineSegment 多直线段。 PolyBezierSegment 多三次方贝塞…

一篇博文,带你入门数据库SQL语言

目录 &#x1f4d6;前言 &#x1f388;SQL的分类 &#x1f3a8;数据库的分类 ✨SQL的基础操作 ⚽SQL常用数据类型 &#x1f3c9;数据库的操作 ⚾创建数据库 &#x1f94e;显示数据库 &#x1f3c0;使用数据库 &#x1f3d0;删除数据库 &#x1f37f;表的操作 &…

Emgu CV4图像处理之打开Tensorflow训练模型17(C#)

本文测试环境&#xff1a; win10 64位 vistual studio 2019 Emgu CV 4.6.0 环境配置准备&#xff1a; 1 新增控制台项目&#xff0c;.net framework为4.7.2 2 把win-x64目录的native目录下的文件全部拷贝到项目的运行目录Debug目录下 3 项目选择x64 4 添加项目引用…

(CVE-2019-0227)Axis<=1.4 远程命令执行漏洞

结尾附上本文的环境和PoC 一、漏洞介绍 漏洞本质是管理员对AdminService的配置错误。当enableRemoteAdmin属性设置为true时&#xff0c;攻击者可以构造WebService调用freemarker组件中的template.utility.Execute类&#xff0c;远程利用AdminService接口进行WebService发布&am…