2023华为OD机试真题Python实现【动态规划/找出重复代码】

2023-11-10

题目描述

小明负责维护项目下的代码,需要查找出重复代码,用以支撑后续的代码优化,请你帮助小明找出重复的代码。重复代码查找方法:以字符串形式给出两行代码(字符审长度1< length < 100,由英文字母、数字和空格组成),找出两行代码中的最长公共子串
注:如果不存在公共子串,返回空字符串
输入描述
输入的参数 text1,text2 分别表示两行代码
输出描述
输出任一最长公共子串
示例一
输入
hello123world1
hello123abc4
输出
hello123
示例二
输入
private_void_method
public_void_method
输出
_void_method

解题思路

这道题使用动态规划解题。dp[i][j] 表示 str1 的前 i 个字符与 str2 的前 j 个字符的最长公共子串长度。状态转移方程如下:

如果 str1[i] == str2[j],则 dp[i + 1][j + 1] = dp[i][j] + 1
如果 str1[i] != str2[j],则 dp[i + 1][j + 1] = 0

参考代码

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

2023华为OD机试真题Python实现【动态规划/找出重复代码】 的相关文章

  • 网络布线概述

    文章目录 一 信号概述 1 什么是信号 2 信号的分类 3 信号在传输过程中产生的失真 4 数字信号的优势 二 双绞线 1 双绞线 2 双绞线分类 3 双绞线标准与分类 三 光纤概述 1 光纤的特点 2 光纤分类 四 双绞线的连接规范 总结
  • 谈谈我的保研经历

    下面这篇博客是17年9月30日写的 当时刚保研结束 就把当时的经历写了一下 经过了这七八个月的时间 又多了一些感悟 等这段时间忙完毕设打算再写一篇 以下是原文 大半年的保研生活 到现在总算有了结果 最终选择了去清华软件学院 我想把这段时间经
  • Qt-OpenCV学习笔记--基本数据结构--Scalar

    一 构造 cv Scalar s1 空构造 cv Scalar s2 s1 拷贝构造 cv Scalar s3 255 赋值构造1 cv Scalar s4 255 255 255 0 赋值构造2 二 函数 cv Scalar s5 255
  • C 语言实例 - 两个整数相加

    include

随机推荐

  • AGL简介

    转载于 https my oschina net lilugirl2005 blog 3078045
  • 从hash函数到王小云的MD5破解

    理论计算机初步 从hash函数到王小云的MD5破解 摘自http zhiqiang org blog 446 html Zhang Zi September 18 2006 8 51 pm Filed under Computer Scie
  • MiniGPT4,开源了!

    梦晨 发自 凹非寺量子位 公众号 QbitAI GPT 4识图功能迟迟不开放 终于有人忍不住自己动手做了一个 MiniGPT 4来了 Demo开放在线可玩 传一张海鲜大餐照片上去 就能直接获得菜谱 传一张商品效果图 就可以让AI写一篇带货文
  • 离散数学-群和环

    半群和独异点 代数系统是由一个非空集合加上一个或几个运算构成的 从这节起 我们要介绍一些特殊的代数系统 所谓特殊 是指这些代数系统中的运算具有特殊的性质 我们要介绍下列一 些代数系统 1 半群 定义 设S是非空集合 是S上的二元运算 如果
  • ctf密码学习题总结

    1 变异凯撒 加密密文 afZ r9VYfScOeO UL RWUc 格式 flag 一看题中说的是凯撒加密 我就赶快使用工具列出了所有的组合 然而发现没有一个是我想要的 于是乎 又重新审题 说的是变异凯撒 看来不能轻敌 得自己动手尝试喽
  • vscode远程连接服务器(remote ssh)+上传本地文件到服务器(sftp)

    一 vscode远程连接服务器 1 点击vscode右边工具栏点击拓展 搜索remote ssh并安装 2 安装完成后 左边工具栏会出现一个电脑图标的远程资源管理器 点击后选择SSH TARGETS的设置 3 然后选择第一个 ssh con
  • 使用connect by进行级联查询

    使用connect by进行级联查询 connect by可以用于级联查询 常用于对具有树状结构的记录查询某一节点的所有子孙节点或所有祖辈节点 来看一个示例 现假设我们拥有一个菜单表t menu 其中只有三个字段 id name和paren
  • 十三道Python练习题

    一 完美立方 编写一个程序 对任给的正整数N N 100 寻找所有的四元组 a b c d 使得a 3 b 3 c 3 d 3 其中a b c d 大于 1 小于等于N 输入一个正整数N N 100 输出 每行输出一个完美立方 输出格式为
  • Anaconda 添加清华镜像源

    在安装tensorflow时 不知道怎么了 一直安装不上去 所以重新配置了下镜像 安装环境 win10 anaconda3 5 删除之前的镜像源 恢复默认状态 conda config remove key channels 添加清华镜像源
  • vue页面的定时刷新

    在做项目时我们肯定会遇到要求该页面几分钟去定时刷新一下获取最新数据这样的情况 那么这个时候我们就要使用setInterval 了 那么我们应该把定时刷新放在什么位置什么时候触发什么时候清除呢 这就需要我们了解vue的生命周期 首先贴一张从官
  • [ Android实战 ] android query: BufferQueue has been abandoned 问题解决

    Android实战 android query BufferQueue has been abandoned 问题解决 背景 日志分析 参考资料 解决方案 源码分析 总结 尊重原创 转载请注明出处 背景 最近在我们的 Camera 应用上发
  • 网络攻击——CSRF攻击

    CSRF攻击 CSRF全称是跨站请求伪造 cross site request forgery CSRF伪装受信任用户 向第三方平台发送恶意请求 CRSF能做的事情包括利用你的身份发邮件 发短信 进行交易转账 甚至盗取账号信息 一个典型的C
  • mysql进阶优化篇04——深入JOIN语句的底层原理

    前 言 作者简介 半旧518 长跑型选手 立志坚持写10年博客 专注于java后端 专栏简介 mysql基础 进阶 主要讲解mysql数据库sql刷题 进阶知识 包括索引 数据库调优 分库分表等 文章简介 本文将介绍JOIN语句的底层原理
  • 2022-06-14 用crontab在linux下定期执行mysql的存储过程

    问题 我们程序有一个日志表 tx log 由于每天数据量增加巨大 所以要每天手动备份3天前的数据到别的表中 tx log ls 并将这些数据在日志表中删除 但有时总会忘记备份 所以想写一个定时器 每天下半夜1点定时执行 思想 1 在mysq
  • STM32Cube学习(2)——定时器中断

    0 引言 单片机 STM32F407ZGT6 仿真器 ST Link V2 开发环境 STM32CubeIDE 1 10 1 功能说明 采用定时器中断的方式 实现LED按照定时器频率闪烁 前情提要 STM32Cube学习 1 点灯 配置 参
  • 基于点云的三维重建_一分钟详解三维重建学习路线

    作者 庞巧遇 来源 公众号 3D视觉工坊 链接 一分钟详解三维重建学习路线 三维重建在计算机视觉中是十分重要的 其中涉及很多的技术内容 为了后来人能少走弯路 也为了对自己的知识框架系统总结 特记录自己的学习路线 1 什么是三维重建 三维重建
  • 决策树,信息熵,信息增益计算----机器学习

    决策树 decision tree 决策树简单介绍 信息量 信息熵 信息增益 决策树简单介绍 决策树是一种基于树状结构来做决策的 是一种常见的机器学习方法 主要做分类 也可以做回归 一棵决策树含有一个根结点 样本全集 若干个内部结点和若干个
  • MYSQL HTTP头部注入

    HTTP头部基础 Accept 浏览器能够处理的内容类型 Accept Charset 浏览器能够显示的字符集 Accept Encoding 浏览器能处理的压缩编码 Accept Language 浏览器当前设置的语言 Connectio
  • Hyper-V 的用途与安装

    什么是 Hyper V Hyper V是微软提出的一种系统管理程序虚拟化技术 能够实现桌面虚拟化 WSL2 和 WSA 与 Hyper V 的关系 Hyper V其实分两个部分 底层的虚拟机平台 上层的虚拟机管理软件 以前的Windows版
  • 2023华为OD机试真题Python实现【动态规划/找出重复代码】

    题目描述 小明负责维护项目下的代码 需要查找出重复代码 用以支撑后续的代码优化 请你帮助小明找出重复的代码 重复代码查找方法 以字符串形式给出两行代码 字符审长度1 lt length lt 100 由英文字母 数字和空格组成 找出两行代码