#leetcode刷題之路30-串聯所有單詞的子串

来源:https://www.cnblogs.com/biat/archive/2019/03/20/10562522.html
-Advertisement-
Play Games

給定一個字元串 s 和一些長度相同的單詞 words。找出 s 中恰好可以由 words 中所有單詞串聯形成的子串的起始位置。註意子串要與 words 中的單詞完全匹配,中間不能有其他字元,但不需要考慮 words 中單詞串聯的順序。 示例 1:輸入: s = "barfoothefoobarman ...


給定一個字元串 s 和一些長度相同的單詞 words。找出 s 中恰好可以由 words 中所有單詞串聯形成的子串的起始位置。
註意子串要與 words 中的單詞完全匹配,中間不能有其他字元,但不需要考慮 words 中單詞串聯的順序。

示例 1:
輸入:
s = "barfoothefoobarman",
words = ["foo","bar"]
輸出:[0,9]
解釋:
從索引 0 和 9 開始的子串分別是 "barfoor" 和 "foobar" 。
輸出的順序不重要, [9,0] 也是有效答案。
示例 2:
輸入:
s = "wordgoodgoodgoodbestword",
words = ["word","good","best","word"]
輸出:[]

思路:首先為了方便比較,把原vector和用於存儲的目標vector都要排序,排序後就可以知道兩者是否完全相等了;剩下的就是暴力迴圈;

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

vector<int> findSubstring(string s, vector<string>& words) {
    sort(words.begin(),words.end());
    vector<int> ans;
    vector<string> temp;
    int n=words.size();
    if(n==0) return ans;
    int len=words[0].length();
    if(s.length()<n*len) return ans;
    for(int i=0;i<s.length()-n*len+1;i++)
    {
        int t=i;
        if(find(words.begin(),words.end(),s.substr(t,len))!=words.end())
        {
            temp.push_back(s.substr(t,len));
            t=t+len;
        }
        for(int j=1;j<n;j++)
        {
            if(find(words.begin(),words.end(),s.substr(t,len))!=words.end())
            {
                temp.push_back(s.substr(t,len));
                t=t+len;
            }
            else
            {
                temp.clear();
                break;
            }
        }
        sort(temp.begin(),temp.end());
        if(temp==words) ans.push_back(i);
        temp.clear();
    }
    return  ans;
}

int main() {
    string s="aaa";
    vector<string> a={"a","a"};
    vector<int> ans=findSubstring(s,a);
    std::cout << ans.size() << std::endl;
    //std::cout << ans[0]<<ans[1] << std::endl;
    return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Spring Boot的由來 相信大家都聽說過Spring框架。 Spring從誕生到現在一直是流行的J2EE開發框架。 隨著Spring的發展,它的功能越來越強大,隨之而來的缺點也越來越明顯,以至於發展到後來變得越來越臃腫,使用起來也非常的麻煩。 到後來由於過於強調配置的靈活性,有時即使只為了加入 ...
  • Template Method(模板方法模式) 將具體處理交給子類 Template Method 就是定義一個操作中的演算法骨架,而將一些步驟延遲到子類中,使得子類可以不改變一個演算法的結構可以定義該演算法的某些特定步驟 。 簡單地說就是 用一些抽象的操作定義一個演算法,而子類將重定義這些操作以提供具體的 ...
  • 假設大家已經安裝好python的環境了。 Windows檢查是否可以運行python腳本 Ctrl+R 輸入 cmd 在命令行中輸入python 如果出現下麵結果,我們就可以開始python的學習了。 第一個python腳本 我使用的python自帶的python shell學習的代碼 打開的視窗如 ...
  • 跨域問題是由於瀏覽器為了防止CSRF攻擊(Cross-site request forgery跨站請求偽造),避免惡意攻擊而帶來的風險而採取的同源策略限制。當一個頁面中使用XMLHTTPRequest(XHR請求)對象發送HTTP請求時,必須保證當前頁面和請求的對象是同源的,即協議、功能變數名稱和埠號要完 ...
  • 使用python進行數據分析時,經常會用Pandas類庫處理數據,將數據轉換成我們需要的格式。Pandas中的有兩個數據結構和處理數據相關,分別是Series和DataFrame。 Series Series是一種類似於一維數組的對象,它有兩個屬性,value和index索引。可以像數組那樣通過索引 ...
  • 1 //幫我們創建容器 2 @RunWith(SpringJUnit4ClassRunner.class) 3 //指定創建容器時使用的配置文件 4 @ContextConfiguration("classpath:applicationContext.xml") 5 public class Te... ...
  • 背景人物介紹 “小明“,98後,9年義務教育比較“優秀”,沒考上大學,或者說沒勇氣參加高考,走的“單招”(你可能沒聽說過,就是高職學校的自主招生),一番努力下,考上了一所普通高職大專學生,高職學校一般為訂單培養,校企合作。大學3年努力一把,即將面臨畢業,6月份之前,需要找到工作! 就業範圍 北方人, ...
  • XML- XML(EXtensibleMarkupLanguage) - 官方文檔http://www.w3school.com.cn/xml/index.asp- 概念:父節點,子節點,先輩節點,兄弟節點,後代節點XPath- XPath(XML Path Language), 是一門在XML文檔 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...