LeetCode-524. 通過刪除字母匹配到字典里最長單詞

1、題目描述:

給你一個字符串?s?和一個字符串數組?dictionary?,找出并返回?dictionary?中最長的字符串,該字符串可以通過刪除?s?中的某些字符得到。

如果答案不止一個,返回長度最長且字母序最小的字符串。如果答案不存在,則返回空字符串。

示例 1:

輸入:s = "abpcplea", dictionary = ["ale","apple","monkey","plea"]
輸出:"apple"

示例 2:

輸入:s = "abpcplea", dictionary = ["a","b","c"]
輸出:"a"

提示:

  • 1 <= s.length <= 1000
  • 1 <= dictionary.length <= 1000
  • 1 <= dictionary[i].length <= 1000
  • s?和?dictionary[i]?僅由小寫英文字母組成

2、代碼:

高逼格代碼:

class Solution {
public:string findLongestWord(string s, vector<string>& dictionary) {// 定義一個 lambda 表達式 compareStr,用于判斷字典中的字符串是否是 s 的子序列auto compareStr = [&](const string& s, const string& dic) -> bool {int i = 0, j = 0; // i 遍歷 s,j 遍歷 dicwhile (i < s.size() && j < dic.size()) { // 雙指針遍歷兩個字符串if (s[i] == dic[j]) { // 如果字符匹配,移動 dic 的指針++j;}++i; // 始終移動 s 的指針}return j == dic.size(); // 如果 dic 被完全匹配,返回 true};// 對字典進行排序:優先按長度降序排列,如果長度相同則按字典序升序排列sort(dictionary.begin(), dictionary.end(),[](const string& a, const string& b) {return (a.size() == b.size()) ? (a < b) : (a.size() > b.size());});// 遍歷排序后的字典,找到第一個符合條件的字符串for (auto str : dictionary) {if (compareStr(s, str)) { // 如果當前字符串是 s 的子序列return str; // 返回該字符串}}// 如果沒有找到符合條件的字符串,返回空字符串return "";}
};

普通代碼 :

class Solution {
public:// 判斷字典中的字符串 dictionary 是否是字符串 s 的子序列bool compareStr(const string& s, const string& dictionary) {int i = 0, j = 0; // i 遍歷 s,j 遍歷 dictionarywhile (i < s.size() && j < dictionary.size()) { // 雙指針遍歷兩個字符串if (s[i] == dictionary[j]) { // 如果字符匹配,移動 dictionary 的指針++j;}++i; // 始終移動 s 的指針}return j == dictionary.size(); // 如果 dictionary 被完全匹配,返回 true}// 主函數:從字典中找到最長且符合條件的字符串string findLongestWord(string s, vector<string>& dictionary) {// 如果字符串 s 為空,直接返回空字符串(題目保證 s 不為空,此檢查可省略)if (s == "") {return "";}// 對字典進行排序:優先按長度降序排列,如果長度相同則按字典序升序排列sort(dictionary.begin(), dictionary.end(),[](const string& a, const string& b) {if (a.size() != b.size()) // 如果長度不同,按長度降序排列return a.size() > b.size();return a < b; // 如果長度相同,按字典序升序排列});// 遍歷排序后的字典,找到第一個符合條件的字符串for (auto str : dictionary) {if (compareStr(s, str)) { // 如果當前字符串是 s 的子序列return str; // 返回該字符串}}// 如果沒有找到符合條件的字符串,返回空字符串return "";}
};

3、解題思路:

1.判斷子序列

這是一個雙指針的問題,雙指針應用在哪呢?就是用在輔助函數里,來判斷某個字符串是否是另一個字符串的子序列,具體方法是使用雙指針,分別遍歷 s 和目標字符串 dictionary,檢查 dictionary是否可以通過刪除 s 的某些字符得到。

2.?優化排序

為了方便比較長度和字典序,可以先對字典進行排序:優先按長度降序排列,如果長度相同則按字典序升序排列。

3.?篩選符合條件的字符串:

因為前面已經將字典進行排序,而且字典優先按長度降序排列,如果長度相同則按字典序升序排列。也就是說,第一個找到的字符串就是最符合要求的答案

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

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

相關文章

TikTok賬戶安全指南:如何取消兩步驗證?

TikTok賬戶安全指南&#xff1a;如何取消兩步驗證&#xff1f; 在這個數字化的時代&#xff0c;保護我們的在線賬戶安全變得尤為重要。TikTok&#xff0c;作為全球流行的社交媒體平臺&#xff0c;其賬戶安全更是不容忽視。兩步驗證作為一種增強賬戶安全性的措施&#xff0c;雖…

面試題之箭頭函數和普通函數有什么區別?

箭頭函數&#xff08;Arrow Function&#xff09;和普通函數&#xff08;Regular Function&#xff09;是 JavaScript 中兩種不同的函數定義方式&#xff0c;它們在語法、上下文&#xff08;this&#xff09;、原型鏈等方面存在顯著區別。以下是它們的主要區別&#xff1a; 1. …

Llama 3.1 本地電腦部署 Linux系統 【輕松簡易】

本文分享在自己的本地電腦部署 llama3.1&#xff0c;而且輕松簡易&#xff0c;快速上手。 這里借助Ollama工具&#xff0c;在Linux系統中進行大模型部署~ Llama3.1&#xff0c;有三個版本&#xff1a;8B、70B、405B Llama 3.1 405B 是第一個公開可用的模型&#xff0c;在常識…

工業安全的智能哨兵:AI如何筑起生產線的“數字防火墻“

工業安全的智能哨兵:AI如何筑起生產線的"數字防火墻" (本文共1420字,閱讀約需4分鐘) 去年某石化廠的反應釜壓力數據出現異常波動,傳統監測系統在15分鐘后才發出警報——而AI模型在23秒前就已預警。這場未遂事故揭示了一個殘酷現實:工業安全監測正在經歷從&qu…

【Bert】自然語言(Language Model)入門之---Bert

every blog every motto: Although the world is full of suffering&#xff0c; it is full also of the overcoming of it 0. 前言 對bert進行梳理 論文&#xff1a; BERT: Pre-training of Deep Bidirectional Transformers for Language Understanding 時間&#xff1a;…

Linux中使用Docker安裝DIFY搭建本地支持庫和Agent

Dify 是一款開源的大語言模型(LLM) 應用開發平臺。它融合了后端即服務&#xff08;Backend as Service&#xff09;和 LLMOps 的理念&#xff0c;使開發者可以快速搭建生產級的生成式 AI 應用。即使你是非技術人員&#xff0c;也能參與到 AI 應用的定義和數據運營過程中。 然而…

開源工具推薦--思維導圖、流程圖等繪制

1. 前言 在工作中&#xff0c;經常要用到各種不同的工具&#xff0c;隨著系統的升級&#xff0c;有些工具也在不斷更新升級。這里收集整理一些好用的開源工具推薦&#xff0c;遵循以下一些基本原則&#xff1a;開源免費&#xff0c;商業工具的有效平替&#xff0c;輕量級&…

Ubuntu 下 nginx-1.24.0 源碼分析 - ngx_create_pool函數

ngx_create_pool 聲明在 src\core\ngx_palloc.h 中 ngx_pool_t *ngx_create_pool(size_t size, ngx_log_t *log); 實現在 src\core\ngx_palloc.c 中 ngx_pool_t * ngx_create_pool(size_t size, ngx_log_t *log) {ngx_pool_t *p;p ngx_memalign(NGX_POOL_ALIGNMENT, size, lo…

ac的dhcp池里option43配錯導致ap無法上線問題排查過程

dhcp池里ac地址配錯&#xff0c;導致ap無法上線問題排查過程 問題&#xff1a;ap手動設置ac的ip正常注冊在線&#xff0c;但dhcp獲得ip和ac地址發現無法在ac上注冊成功。 組網&#xff1a; ac旁路結構&#xff0c;路由器lan口地址172.16.1.1&#xff0c;開dhcp服務&#xff0…

IntelliJ IDEA中Maven配置全指南

一、環境準備與基礎配置 1.1 Windows 環境下載并配置 Maven 見此篇博文&#xff1a;環境配置 1.2 IDEA配置步驟 打開設置面板&#xff1a;File → Settings → Build → Build Tools → Maven 關鍵配置項&#xff1a; Maven home path E:\apache-maven-3.9.9 &#xff08;…

存儲區域網絡(SAN)管理

存儲區域網絡&#xff08;Storage Area Network&#xff0c;SAN&#xff09;采用網狀通道&#xff08;Fibre Channel &#xff0c;簡稱FC&#xff09;技術&#xff0c;通過FC交換機連接存儲陣列和服務器主機&#xff0c;建立專用于數據存儲的區域網絡。SAN提供了一種與現有LAN連…

使用vue-office報錯TypeError: ft.createElementVNode is not a function

支持多種文件(.docx、.xlsx、.xls、.pdf、.pptx)預覽的vue組件庫&#xff0c;支持vue2/3。也支持非Vue框架的預覽。 不支持.doc、.ppt&#xff08;2003年及以前的版本&#xff09; 官網&#xff1a;https://www.npmjs.com/package/vue-office/excel?activeTabreadme 官方有實…

Ubuntu部署ktransformers

準備工作 一臺服務器 CPU&#xff1a;500G GPU&#xff1a;48G&#xff08;NVIDIA4090&#xff09; 系統&#xff1a;Ubuntu20.04&#xff08;github的文檔好像用的是22.04&#xff09; 第一步&#xff1a;下載權重文件 1.下載hfd wget https://hf-mirror.com/hfd/hfd.s…

C++初階——簡單實現vector

目錄 1、前言 2、Vector.h 3、Test.cpp 1、前言 簡單實現std::vector類模板。 相較于前面的string&#xff0c;vector要注意&#xff1a; 深拷貝&#xff0c;因為vector的元素可能是類類型&#xff0c;類類型元素可以通過賦值重載&#xff0c;自己實現深拷貝。 迭代器失效…

全志A133 android10 適配SLM770A 4G模塊

一&#xff0c;模塊基本信息 1.官方介紹 SLM770A是美格智能最新推出的一款LTE Cat.4無線通訊模組&#xff0c;最大支持下行速率150Mbps及上行速率50Mbps。同時向下兼容現有的3G和2G網絡&#xff0c;以確保即使在偏遠地區也可以進行網絡通信。 SLM770A模組支持分集接收和MIMO技…

微信小程序:多菜單欄設計效果

一、實現效果 二、代碼 wxml 編輯前端界面,步驟 菜單邏輯: 逐步取出數組中的項,首先取出頂部菜單項,然后選中后取出選中的底部數據(左側菜單+右側內容),然后點擊左側菜單取出選中的左側菜單對應的右側內容 ①這里我的數據是全部封裝到一個數組對象的,首先我的循環…

C++基礎知識學習記錄—string類

string實際上是C內置的一個類&#xff0c;內部對char *進行了封裝&#xff0c;不用擔心數組越界問題&#xff0c;string類中&#xff0c;除了上課講解的函數外&#xff0c;還有很多函數可以使用&#xff0c;可以自行查閱文檔。 構造函數原型&#xff1a; string(); //創建一個…

Ollama+DeepSeek+Open-WebUi

環境準備 Docker Ollama Open-WebUi Ollama 下載地址&#xff1a;Ollama docker安裝ollama docker run -d \ -v /data/ollama/data:/root/.ollama \ -p 11434:11434 \ --name ollama ollama/ollama 下載模型 Ollama模型倉庫 # 示例&#xff1a;安裝deepseek-r1:7b doc…

設計模式--訪問者模式【行為型模式】

設計模式的分類 我們都知道有 23 種設計模式&#xff0c;這 23 種設計模式可分為如下三類&#xff1a; 創建型模式&#xff08;5 種&#xff09;&#xff1a;單例模式、工廠方法模式、抽象工廠模式、建造者模式、原型模式。結構型模式&#xff08;7 種&#xff09;&#xff1…

前端循環全解析:JS/ES/TS 循環寫法與實戰示例

循環是編程中控制流程的核心工具。本文將詳細介紹 JavaScript、ES6 及 TypeScript 中各種循環的寫法、特性&#xff0c;并通過實際示例幫助你掌握它們的正確使用姿勢。 目錄 傳統三劍客 for 循環 while 循環 do...while 循環 ES6 新特性 forEach for...of for...in 數組…