华为OD机试真题B卷 JavaScript 实现【公共子串计算】,附详细解题思路

news2024/11/24 22:24:46

在这里插入图片描述

一、题目描述

给定两个只包含小写字母的字符串,计算两个字符串的最大公共子串的长度。

注:子串的定义指一个字符串删掉其部分前缀和后缀(也可以不删)后形成的字符串。

二、输入描述

输入两个只包含小写字母的字符串。

三、输出描述

输出一个整数,代表最大公共子串的长度。

四、解题思路

  1. 首先读取输入的两个字符串;
  2. 将字符串长度较短的作为 s1,长度较长的作为 s2;
  3. 初始化最大公共子串的长度 n 为 0;
  4. 使用两层循环遍历 s1 的所有子串,从索引 i 开始到索引 j,其中 i 不大于 j;
  5. 在内层循环中,判断 s2 是否包含当前子串,使用 contains 方法进行判断;
  6. 如果 s2 包含当前子串,则更新最大公共子串的长度 n,取当前子串的长度(j - i)和 n 中的较大值;
  7. 如果找到了包含当前子串的情况,就可以跳出内层循环;
  8. 循环结束后,输出最大公共子串的长度 n。

五、JavaScript算法源码

function findLongestCommonSubstring(s1, s2) {
    const shorterStr = s1.length < s2.length ? s1 : s2;
    const longerStr = s1.length < s2.length ? s2 : s1;
    let maxLen = 0;

    for (let i = 0; i < shorterStr.length; i++) {
        for (let j = shorterStr.length; j > i; j--) {
            if (longerStr.includes(shorterStr.substring(i, j))) {
                maxLen = Math.max(maxLen, j - i);
                break;
            }
        }
    }

    return maxLen;
}

六、效果展示

在这里插入图片描述


🏆下一篇:华为OD机试真题 JavaScript 实现【相对开音节】【2022Q4 100分】,附详细解题思路

🏆本文收录于,华为OD机试(JavaScript)真题(A卷+B卷)

每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。

在这里插入图片描述

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

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

相关文章

chatgpt赋能python:Python使用的排大小方式全解析:关于SEO的学习!

Python使用的排大小方式全解析&#xff1a;关于SEO的学习&#xff01; 对于一个Python工程师来说&#xff0c;深度理解编程语言的基础知识总是非常重要的&#xff0c;包括了语法、函数、模块、数据结构以及算法等等。而在SEO领域&#xff0c;Python所采用的排大小方式&#xf…

jdk动态代理和cglb动态代理

目录 概述 JDK动态代理 cglb动态代理 概述 动态代理和静态代理都是代理模式的实现方式&#xff0c;其主要区别在于代理类生成的时机和方式。 静态代理是在编译时就确定了代理类的代码&#xff0c;在程序运行前就已经存在了代理类的class文件。代理类与委托类的关系在编译时就…

STM32F407移植1588v2(ptpd)

硬件&#xff1a; STM32F407ZGT6开发板 软件&#xff1a; VSCode arm-none-eabi-gcc openOCD st-link 在github搜到一个在NUCLEO-F429ZI开发板上移植ptpd的example&#xff0c;因为和F407差别很小&#xff0c;所以就打算用这个demo移植到手头的开发板上。因为目前只需要…

【C语言】VScode中配置C语言/C++运行环境(保姆级图文)

目录 省流助手1. 下载安装VScode2. 下载编译器MinGW并解压3. 将MinGW添加至环境变量4. 安装vscode的插件5. 运行代码6. 调整和优化&#xff08;这部分转自零流火星动力猿 2022.4.12&#xff09;总结 欢迎关注 『C语言』 系列&#xff0c;持续更新中 欢迎关注 『C语言』 系列&am…

初识滴滴交易策略之三:供需调节

本篇文章分为&#xff1a; 1.什么是交易市场中的供需&#xff1f; 供需的动态性供需的相互作用 2.滴滴业务场景涉及的供需调节技术 供需感知和供需预测 时序预测供需调节以提升市场匹配程度&#xff0c;保持供需平衡 整数规划为司机规划更好的出车方式 模仿学习&#xff08;Imi…

【工具篇】Maven使用${revision}实现多模块版本统一管理

背景说明 在使用Maven多模块结构工程时&#xff0c;版本管理是一件很繁琐且容易出错的事情。每次升级版本号都要手动调整或者通过mvn versions:set -DnewVerionxx命令去更改每一个子模块的版本号&#xff0c;非常的不方便&#xff0c;而且会改动所有的模块&#xff0c;出现如下…

Vue语法(4)

目录 1. 自定义指令 1.1 使用方法 1.2 实际案例 1.3 全局指令和局部指令 2. 组件对象 2.1 组件基础 2.2 组件对象 2.3 组件的属性——props 2.4 全局组件和局部组件 2.5 单文件组件 1. 概念&#xff1a; 2. 配置开发环境的指令&#xff1a; 3. 单文件组…

云迁移为业务赋能,跨出数字化转型第一步

新钛云服已累计为您分享752篇技术干货 云迁移如何赋能企业业务 随着科技的迅猛发展和数字化转型的浪潮席卷全球&#xff0c;越来越多的企业开始意识到云计算的重要性和潜力。在这个数字化时代&#xff0c;企业不再满足于传统的IT架构和数据中心&#xff0c;而是追求更高效、灵活…

《JAX可微分编程》包邮送书五本

文章目录 前言JAX到底是什么&#xff1f;书籍内容介绍包邮送书5本 前言 2015年&#xff0c;Google Brain开放了一个名为「TensorFlow」的研究项目&#xff0c;这款产品迅速流行并成为人工智能业界的主流深度学习框架&#xff0c;塑造了现代机器学习的生态系统。 7年后&#x…

Shell脚本文本三剑客之sed编辑器

目录 一、sed编辑器简介 二、sed工作流程 三、sed命令 四、sed命令的使用 1.sed打印文件内容&#xff08;p&#xff09; &#xff08;1&#xff09;打印文件所有行 &#xff08;2&#xff09;打印文件指定行 2.sed增加、插入、替换行&#xff08;a、i、c&#xff09; …

CVPR 2023 | 视频AIGC,预测/插帧/生成/编辑

1、A Dynamic Multi-Scale Voxel Flow Network for Video Prediction 视频预测&#xff08;video prediction&#xff09;的性能已经通过先进的深度神经网络大幅提高。然而&#xff0c;大多数当前的方法存在着大的模型尺寸和需要额外的输入&#xff08;如&#xff0c;语义/深度…

【Instruction Tuning】ChatGLM 微调实战(附源码)

在之前的文章中&#xff0c;我们已经讲过了 ChatGPT 的三个主要流程&#xff1a; SFT&#xff1a;通过 Instruction Tuning 来微调一个监督学习模型。Reward Model&#xff1a;通过排序序列来训练一个打分模型。Reinforcement Learning&#xff1a;通过强化学习来进一步优化模…

【MySQL新手入门系列一】:手把手教你入门MySQL

如果您是一位刚刚开始学习MySQL的新手&#xff0c;本文将为您提供一些实用的入门知识和技巧&#xff0c;帮助您快速上手。 本篇文章将以windows为例&#xff0c;介绍MySQL的基础知识&#xff0c;以及如何安装、卸载、配置和使用它。 导读 一、概览1.1 MySQL是什么1.2 为什么要学…

一文掌握linux网络相关命令

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和…

阿里企业邮箱登录入口

阿里企业邮箱登录入口&#xff1a;https://qiye.aliyun.com/ 阿里企业邮箱可以使用邮箱账号登录&#xff0c;也可以使用钉钉账号登录&#xff0c;打开登录入口&#xff0c;如下图&#xff1a; 阿里企业邮箱登录入口 企业邮箱购买页面&#xff1a;aliyunbaike.com/go/mail免费企…

归并排序和快速排序(C++)

归并排序是一种经典的排序算法&#xff0c;也被称为“归并算法”。它的基本思想是将待排序数组分成若干个子数组&#xff0c;每个子数组都是有序的&#xff0c;然后将这些子数组合并成一个大的有序数组。 具体实现过程如下&#xff1a; 将待排序数组不断划分为左右两个子数组&…

IMX6ULL裸机篇之SPI实验-SPI主控代码实现

一. SPI 实验 SPI实验&#xff1a;学习如何使用 I.MX6U 的 SPI 接口来驱动 ICM-20608&#xff0c;读取 ICM-20608 的六轴数据。 本文学习 SPI主控芯片的代码编写。其中&#xff0c;包括SPI工作模式设置&#xff0c;主从模式设置&#xff0c;时钟配置等实现。 二. SPI 主控芯…

光学介质材料——光学膜

手机、平板、智能电视等设备之所以能够发光发亮离不开一个重要的组成材料——光学膜。那光学膜是什么回事呢&#xff1f; 光学膜是指在光学元件或独立基板上&#xff0c;制镀或涂布一层或多层介电质膜或金属膜或这两类膜的组合&#xff0c;以改变光波的传递特性&#xff0c;包…

MySQL索引:让你的数据库查询快到起飞!

&#x1f495;世界上最美好的东西之一&#xff0c;就是你每天都有机会开始全新的一天。&#x1f495; &#x1f43c;作者&#xff1a;不能再留遗憾了&#x1f43c; &#x1f386;专栏&#xff1a;MySQL学习&#x1f386; &#x1f697;本文章主要内容&#xff1a;详细介绍如何查…

SSD、内存和 L1 Cache 相比速度差多少倍

一道面试题&#xff1a;SSD、内存和 L1 Cache 相比速度差多少倍&#xff1f; 其实比起复杂的技术问题&#xff0c;我更喜欢在面试中提问这种像生活常识一样的简单问题。因为我觉得&#xff0c;复杂的问题是由简单的问题组成的&#xff0c;如果你把简单的问题学扎实了&#xff…