華為OD機考題(HJ65 查找兩個字符串a,b中的最長公共子串)

前言

經過前期的數據結構和算法學習,開始以OD機考題作為練習題,繼續加強下熟練程度。

描述

查找兩個字符串a,b中的最長公共子串。若有多個,輸出在較短串中最先出現的那個。

注:子串的定義:將一個字符串刪去前綴和后綴(也可以不刪)形成的字符串。請和“子序列”的概念分開!

數據范圍:字符串長度1≤𝑙𝑒𝑛𝑔𝑡?≤300?1≤length≤300?

進階:時間復雜度:𝑂(𝑛3)?O(n3)?,空間復雜度:𝑂(𝑛)?O(n)?

輸入描述:

輸入兩個字符串

輸出描述:

返回重復出現的字符

示例1

輸入:

abcdefghijklmnop

abcsafjklmnopqrstuvw
輸出:
jklmnop

實現原理與步驟

1.從1個字符到N字符逐次比較字符的一致性,用到了java原生的contains方法

實現代碼(暴力算法)

import java.util.Scanner;// 注意類名必須為 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);String word1 = in.nextLine();String word2 = in.nextLine();int len1 = word1.length();int len2 = word2.length();if (len1 < len2) {String temp = word1;word1 = word2;word2 = temp;}int maxLen = 0;String res = "";for (int i = 0; i < word2.length(); i++) {for (int j = 0; j <=i; j++) {String subStr = word2.substring(j, i+1);if (word1.contains(subStr) && subStr.length() > maxLen) {res = subStr;maxLen = subStr.length();}}}System.out.println(res);}
}

實現代碼(動態規劃)

import java.util.*;
public class Main {public static void main(String[]args) {Scanner sc = new Scanner(System.in);while (sc.hasNext()) {String s1 = sc.nextLine();String s2 = sc.nextLine();System.out.println(longString(s1, s2));}}// 動態規劃public static String longString(String str1, String str2) {String temp = "";// 保證str1是較短字符串if (str1.length() > str2.length()) {temp = str1;str1 = str2;str2 = temp;}int m = str1.length();int n = str2.length();// 表示在較短字符串str1以第i個字符結尾,str2中以第j個字符結尾時的公共子串長度。int[][] dp = new int[m+1][n+1];// 匹配字符,并記錄最大值的str1的結尾下標int max = 0;int index = 0;// 從左向右遞推,i為短字符串str1的結尾索引,j為str2的結尾索引for (int i = 1; i <=m; i++) {for (int j = 1; j <=n; j++) {if (str1.charAt(i - 1) == str2.charAt(j - 1)) {// 相等則計數dp[i][j] = dp[i - 1][j - 1] + 1;// 不斷更新變量if (dp[i][j] > max) {max = dp[i][j];index = i;}}}}// 截取最大公共子串return str1.substring(index - max, index);}
}

1.QA:

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/41586.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/41586.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/41586.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Git 】規范 Git 提交信息的工具 Commitizen

Commitizen是一個用于規范Git提交信息的工具&#xff0c;它旨在幫助開發者生成符合一定規范和風格的提交信息&#xff0c;從而提高代碼維護的效率&#xff0c;便于追蹤和定位問題。以下是對Commitizen的詳細介紹。 1、Commitizen的作用與優勢 規范提交信息&#xff1a;通過提供…

C# Application.DoEvents()的作用

文章目錄 1、詳解 Application.DoEvents()2、示例處理用戶事件響應系統事件控制臺輸出游戲和多媒體應用與操作系統的交互 3、注意事項總結 Application.DoEvents() 是 .NET 框架中的一個方法&#xff0c;它主要用于處理消息隊列中的事件。在 Windows 應用程序中&#xff0c;當一…

Oracle PL / SQL INTERVAL數據類型

INTERVAL YEAR TO MONTH數據類型 INTERVAL YEAR TO MONTH存儲和操作年和月的間隔。 語法是&#xff1a; INTERVAL YEAR[(precision)] TO MONTH precision指定“years”字段中的數字位數。 我們必須在0..4的范圍內使用整數字面值。默認值為2。 以下代碼顯示如何將字面值分配…

基于16通道AD采集(CL1616和AD7616)的FPGA設計簡介

Cl1616是一款 16 位 DAS,支持對 16 個通道進行雙路同步采樣。CL1616 采用 5 V 單電源供電,可以 處理10 V、5 V 和2.5 V 真雙極性輸入信號,同時每對通道均能以高達 1 MSPS 的吞吐速率和 90 dB SNR 采樣。利用片內過采樣模式可實現更高的 SNR 性能。 AD7616與CL1616軟硬件兼容…

實驗四 圖像增強—灰度變換之直方圖變換

一&#xff0e;實驗目的 1&#xff0e;掌握灰度直方圖的概念及其計算方法&#xff1b; 2&#xff0e;熟練掌握直方圖均衡化計算過程&#xff1b;了解直方圖規定化的計算過程&#xff1b; 3&#xff0e;了解色彩直方圖的概念和計算方法 二&#xff0e;實驗內容&#xff1a; …

ArcGIS Pro SDK (八)地理數據庫 1 地理數據庫和數據存儲

ArcGIS Pro SDK &#xff08;八&#xff09;地理數據庫 1 地理數據庫和數據存儲 文章目錄 ArcGIS Pro SDK &#xff08;八&#xff09;地理數據庫 1 地理數據庫和數據存儲1 打開給定路徑的文件地理數據庫2 使用連接屬性打開企業級地理數據庫3 使用 sde 文件路徑打開企業級地理數…

Bootstrap 提示工具

Bootstrap 提示工具 Bootstrap 是一個流行的前端框架,它提供了一套豐富的工具和組件,用于快速開發響應式和移動設備優先的網頁。其中,提示工具(Tooltip)是 Bootstrap 提供的一個非常有用的組件,它可以在用戶將鼠標懸停在某個元素上時顯示額外的信息。本文將詳細介紹 Boo…

課設:選課管理系統(Java+MySQL)

在本博客中&#xff0c;我將介紹用Java、MySQL、JDBC和Swing GUI開發一個簡單的選課管理系統。 技術棧 Java&#xff1a;用于編寫應用程序邏輯MySQL&#xff1a;用于存儲和管理數據JDBC&#xff1a;用于連接Java應用程序和MySQL數據庫Swing GUI&#xff1a;用于構建桌面應用程…

555 定時器芯片工作原理

在本教程中&#xff0c;您將學習如何使用 555 定時器做一些有趣的事情。許多人用它做的第一件事就是制造閃爍的燈光。但這只是用該芯片可以做很多事情的簡單示例之一。您還可以控制電機、創建鬧鐘、創建樂器等等。 讓我們先來概覽一下這些引腳。 555 定時器引腳排列 引腳 1 接地…

【SpringCloud】概述 -- 微服務入門

在Java的整個學習過程中&#xff0c;大家勢必會聽見一些什么分布式-微服務、高并發、高可用這些專業術語&#xff0c;給人的感覺很高級&#xff0c;有一種高深莫測的感覺。可以看一下這篇博客對這些技術架構的演變有一個初步的認識: 服務端?并發分布式結構演進之路-CSDN博客文…

image媒體組件屬性配合swiper輪播

圖片組件&#xff08;image&#xff09; 先插入個圖片試試&#xff0c;插入圖片用src屬性&#xff0c;這是圖片&#xff1a; 代碼如下&#xff1a; <template><view><swiper indicator-dots indicator-color "#126bae" indicator-active-color &…

Jectpack Navigation組件設置統一跳轉動畫

Activity的跳轉一般通過Theme設置即可&#xff0c;但是Framment的跳轉除了NavigationUI類提供的方法會有動畫以外&#xff0c;直接調用navigate方法是沒有動畫的。 網上的實現個人認為比較麻煩&#xff0c;幫自己寫了一套&#xff0c;主要就是自定義NavHostFragement和Fragmen…

CobaltStrike的內網安全

1.上線機器的Beacon的常用命令 2.信息收集和網站克隆 3.釣魚郵件 4.CS傳遞會話到MSF 5.MSF會話傳遞到CS 1上線機器的Beacon的常用命令 介紹&#xff1a;CobaltStrike分為服務端和客戶端&#xff0c;一般我們將服務端放在kali&#xff0c;客戶端可以在物理機上面&#xff0…

tongweb 部署軟航流版簽一體化應用示例 提示跨域錯誤CORS ERROR

目錄 問題現象與描述 解決辦法 原理解析 什么是CORS 瀏覽器跨域請求限制 跨域問題解決方法 跨域請求流程 瀏覽器請求分類解析 http請求方法簡介 問題現象與描述 重慶軟航科技有限公司提供了一套針對針對word、excel等流式文件轉換成PDF版式文件并進行版式文件在線簽章…

ai積累-具體應用的大概設想

這些場景展示了以 ChatGPT 為代表的生成式 AI 可能的具體應用&#xff1a; 教育輔助&#xff1a; AI 可以充當學生的個性化輔導老師&#xff0c;提供定制化的學習材料和練習。例如&#xff0c;它可以生成針對學生能力水平和興趣的數學問題或歷史教學文章。 客戶支持&#xff1…

LESS 的嵌套寫法有什么優勢?

LESS的嵌套寫法可以提高代碼的可讀性和維護性。通過將相關的樣式規則嵌套在父選擇器中&#xff0c;可以更清晰地表達樣式之間的層級關系&#xff0c;避免重復的代碼&#xff0c;并且使樣式結構更加整潔。 例如&#xff0c;假設有以下HTML結構&#xff1a; <div class"…

Qt 加載圖片的幾種方式 以及加載 loading

項目中經常使用加載圖片&#xff1a; 常用有兩種方式&#xff1a; 1.使用 QWidget 加載圖片&#xff1a; 效果&#xff1a; 樣例源碼&#xff1a; int pict_H ui->widgetImage->height();int pict_W ui->widgetImage->width();ui->widgetImage->setFixe…

白騎士的C語言教學高級篇 3.4 C語言中的算法

算法是解決問題的核心。無論是排序、搜索&#xff0c;還是遞歸與動態規劃&#xff0c;算法的選擇和實現對程序的效率和性能有著重要影響。本節將介紹幾種常見的算法&#xff0c;包括排序算法、搜索算法&#xff0c;以及遞歸和動態規劃的應用。 排序算法 排序算法是將一組數據按…

昇思25天學習打卡營第17天|SSD目標檢測

學AI還能贏獎品&#xff1f;每天30分鐘&#xff0c;25天打通AI任督二脈 (qq.com) SSD目標檢測 模型簡介 SSD&#xff0c;全稱Single Shot MultiBox Detector&#xff0c;是Wei Liu在ECCV 2016上提出的一種目標檢測算法。使用Nvidia Titan X在VOC 2007測試集上&#xff0c;SSD…

使用 CloudWatch + SNS + Lambda 實現多渠道告警系統

1. 簡介 在現代云計算環境中,及時和有效的監控告警對于維護系統的穩定性至關重要。本文將介紹如何使用 AWS CloudWatch、Simple Notification Service (SNS) 和 Lambda 函數構建一個多渠道告警系統,包括郵件告警、釘釘機器人告警和電話語音告警。 2. 系統架構 整個系統的工…