華為OD E卷(100分)23-連續字母長度

前言

? ? ? ? 工作了十幾年,從普通的研發工程師一路成長為研發經理、研發總監。臨近40歲,本想辭職后換一個相對穩定的工作環境一直干到老, 沒想到離職后三個多月了還沒找到工作,愁腸百結。為了讓自己有點事情做,也算提高一下自己的編程能力,無聊之余打算用一些大廠的編程題練練手。希望通過這些分享能夠幫到一些人,也希望能和看到此文的大神們溝通交流,提升自己,更希望在此期間能夠找到一份理想的工作。

題目描述

????????給定一個字符串Q,只包含大寫字母,求在包含同一字母的子串中,長度第k長的子串的長度,相同字母只取最長的那個子串。

輸入

  1. 第一行有一個子串(1<長度<=100),只包含大寫字母。
  2. 第二行為 k 的值

輸出

????????輸出連續出現次數第 k 多的字母的次數。

示例?

示例1

輸入
AAAAHHHBBCDHHHH
3
輸出
2
說明
同一字母連續出現的最多的是A和H,四次;
第二多的是H,3次,但是H已經存在4個連續的,故不考慮:
下個最長子串是BB,所以最終答案應該輸出2.

示例2

輸入
AABAAA
2
輸出
1
說明
同一字母連續出現的最多的是A,三次;第二多的還是A,兩次,但A已經存在最大連續次數三次故不考慮:
下個最長子串是B,所以輸出1。

示例3

輸入
ABC
4
輸出
-1
說明
只含有3個包含同一字母的子串,小于k,輸出-1

示例4

輸入
ABC
2
輸出
1
說明
三個子串長度均為1,所以此時k=1,k=2,k=3這三種情況均輸出1。特此說明,避免歧義。

解題思路

????????將字母對應的長度放到 Map 中, 最后對 values 進行排序, 取 k 個?

題解?

Java實現

package huawei.e100;import java.util.Arrays;
import java.util.Scanner;
import java.util.TreeMap;/**
* @author arnold
* @date 2024年12月14日
* 
*/
public class T23 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);while(sc.hasNext()) {String str = sc.nextLine();int s = sc.nextInt();sc.nextLine();System.out.println( run(str, s));}}static int run(String str, int order) {TreeMap<Character, Integer> orders = new TreeMap<>();int n = 1;for (int i = 1; i < str.length(); i++) {if(str.charAt(i) == str.charAt(i-1)) {n++;} else {n = 1;}if (orders.containsKey(str.charAt(i))) {orders.put(str.charAt(i), Math.max(n, orders.get(str.charAt(i))));} else {orders.put(str.charAt(i), n);}}Integer[] strLens = orders.values().toArray(new Integer[orders.size()]);Arrays.sort(strLens);return  strLens.length-order >=0? strLens[strLens.length - order] :-1;}}

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

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

相關文章

VS2019中無法跳轉定義_其中之一情況

我習慣了使用VS2019看stm的代碼&#xff1b; 遇到的問題&#xff0c;在導入代碼后&#xff0c;發現有些函數調用不能跳轉到定義&#xff1b; 問題描述步驟 1、導入代碼 2、跳轉&#xff0c;無法跳轉 1、中文路徑 2、刪除.vs文件 和網上查的都沒辦法解決 最后發現是VS不支持 …

讓 Win10 上網本 Debug 模式 QUDPSocket 信號槽 收發不丟包的方法總結

在前兩篇文章里&#xff0c;我們探討了不少UDP丟包的解決方案。經過幾年的摸索測試&#xff0c;其實方法非常簡單, 無需修改代碼。 1. Windows 下設置UDP緩存 這個方法可以一勞永逸解決UDP的收發丟包問題&#xff0c;只要添加注冊表項目并重啟即可。即使用Qt的信號與槽&#…

【設計模式】觀察者模式深度講解

文章目錄 概覽一、定義與特點二、角色與職責三、實現方式四、應用場景五、優缺點 Java實現Python實現 概覽 觀察者模式&#xff08;Observer Pattern&#xff09;是一種行為型設計模式&#xff0c;它定義了一種一對多的依賴關系&#xff0c;讓多個觀察者對象同時監聽某一個主題…

Elasticsearch:ES|QL 中的全文搜索 - 8.17

細心的開發者如果已經閱讀我前兩天發布的文章 “Elastic 8.17&#xff1a;Elasticsearch logsdb 索引模式、Elastic Rerank 等”&#xff0c;你就會發現在 8.17 的發布版中&#xff0c;有一個重要的功能發布。那就是 ES|QL 開始支持全文搜索了。在今天的文章中我們來嘗試一下。…

SQL和Python 哪個更容易自學?

SQL和Python不是一個物種&#xff0c;Python肯定更難學習。如果你從事數據工作&#xff0c;我建議先學SQL、有余力再學Python。因為SQL不光容易學&#xff0c;而且前期的投入產出比更大。 SQL是數據查詢語言&#xff0c;場景限于數據查詢和數據庫的管理&#xff0c;對大部分數據…

【unity】從零開始制作平臺跳躍游戲--界面的認識,添加第一個角色!

在上一篇文章中&#xff0c;我們已經完成了unity的環境配置與安裝?? 【Unity】環境配置與安裝-CSDN博客 接下來&#xff0c;讓我們開始新建一個項目吧&#xff01; 新建項目 首先進入unityHub的項目頁面&#xff0c;點擊“新項目”&#xff1a; 我們這個系列將會以2D平臺…

怎么禁用 vscode 中點擊 go 包名時自動打開瀏覽器跳轉到 pkg.go.dev

本文引用怎么禁用 vscode 中點擊 go 包名時自動打開瀏覽器跳轉到 pkg.go.dev 在 vscode 設置項中配置 gopls 的 ui.navigation.importShortcut 為 Definition 即可。 "gopls": {"ui.navigation.importShortcut": "Definition" }ui.navigation.i…

Unity3D實現抽象類的應用場景例子

系列文章目錄 unity知識點 文章目錄 系列文章目錄??前言??一、示例??二、使用步驟??三、抽象類和接口的區別??3-1、抽象類??3-2、接口類??壁紙分享??總結??前言 假設我們正在制作一個游戲,游戲中有多種不同類型的角色,這些角色都有一些共同的行為(比如移…

數據倉庫工具箱—讀書筆記01(數據倉庫、商業智能及維度建模初步)

數據倉庫、商業智能及維度建模初步 記錄一下讀《數據倉庫工具箱》時的思考&#xff0c;摘錄一些書中關于維度建模比較重要的思想與大家分享&#x1f923;&#x1f923;&#x1f923; 博主在這里先把這本書"變薄"~有時間的小伙伴可以親自再讀一讀&#xff0c;感受一下…

docker啟動一個helloworld(公司內網服務器)

這里寫目錄標題 容易遇到的問題&#xff1a;1、docker連接問題 我來介紹幾種啟動 Docker Hello World 的方法&#xff1a; 最簡單的方式&#xff1a; docker run hello-world這會自動下載并運行官方的 hello-world 鏡像。 使用 Nginx 作為 Hello World&#xff1a; docker…

計算機組成原理(五):程序裝載

在計算機組成原理中&#xff0c;程序裝載&#xff08;Program Loading&#xff09;是指將程序從外存&#xff08;如磁盤&#xff09;加載到內存中&#xff0c;并為其運行做好準備的過程。程序裝載是實現程序從靜態存儲狀態到動態運行狀態的關鍵環節&#xff0c;涉及地址映射、內…

Python+OpenCV系列:模版匹配

文章目錄 1. 模板匹配基本原理2. cv2.matchTemplate() 函數函數原型&#xff1a; 3. 模板匹配步驟4. 單目標模板匹配示例5. 多目標模板匹配多目標模板匹配示例代碼解析&#xff1a; 6. 多模板匹配多模板匹配示例代碼解析 7. 總結 模板匹配是一種在圖像中尋找模板的位置的方法。…

基于IEEE 802.1Qci的時間敏感網絡(TSN)主干架構安全分析及異常檢測系統設計

中文標題&#xff1a;基于IEEE 802.1Qci的時間敏感網絡&#xff08;TSN&#xff09;主干架構安全分析及異常檢測系統設計 英文標題&#xff1a;Security Analysis of the TSN Backbone Architecture and Anomaly Detection System Design Based on IEEE 802.1Qci 作者信息&…

怎樣提升企業網絡的性能?

企業網絡的穩定性和高效性直接影響員工的工作效率。以下從多維度分析了一些有效策略&#xff0c;幫助公司提升網絡性能&#xff0c;營造更高效的辦公環境。 1. 升級網絡設備 采用性能更高的網絡硬件是優化網絡體驗的重要基礎。選擇支持高吞吐量、低延遲的設備&#xff08;如企業…

scala基礎_數據類型概覽

Scala 數據類型 下表列出了 Scala 支持的數據類型&#xff1a; 類型類別數據類型描述Scala標準庫中的實際類基本類型Byte8位有符號整數&#xff0c;數值范圍為 -128 到 127scala.Byte基本類型Short16位有符號整數&#xff0c;數值范圍為 -32768 到 32767scala.Short基本類型I…

力扣239.滑動窗口最大值

文章目錄 一、前言二、單調隊列 一、前言 力扣239.滑動窗口最大值 滑動窗口最大值&#xff0c;這道題給定一個數組&#xff0c;以及一個窗口的長度&#xff0c;這個窗口會往后滑動&#xff0c;直到數組最后一個元素。 要求每個滑動窗口的中的最大值。對于這道題&#xff0c;我…

mac 安裝CosyVoice (cpu版本)

CosyVoice 介紹 CosyVoice 是阿里研發的一個tts大模型 官方項目地址&#xff1a;https://github.com/FunAudioLLM/CosyVoice.git 下載項目&#xff08;非官方&#xff09; git clone --recursive https://github.com/v3ucn/CosyVoice_for_MacOs.git 進入項目 cd CosyVoic…

電腦插件修復工具

DirectX修復工具 鏈接&#xff1a;夸克網盤分享

Maven 安裝配置(詳細教程)

文章目錄 一、Maven 簡介二、下載 Maven三、配置 Maven3.1 配置環境變量3.2 Maven 配置3.3 IDEA 配置 四、結語 一、Maven 簡介 Maven 是一個基于項目對象模型&#xff08;POM&#xff09;的項目管理和自動化構建工具。它主要服務于 Java 平臺&#xff0c;但也支持其他編程語言…

Scala中的泛型特質

代碼如下&#xff1a; package test41 //泛型特質 object test3 { //定義一個日志//泛型特質&#xff0c;X是泛型名稱&#xff0c;可以更改。trait Logger[X] {val content: Xdef show():Unit }class FileLogger extends Logger[String] {override val content: String "…