最長不重覆子串

来源:http://www.cnblogs.com/gcoder/archive/2017/09/08/7495970.html
-Advertisement-
Play Games

問題描述:給定一個字元串,找出這個字元串中最長的不重覆串。 比如:對於字元串"abba",那麼返回的結果應該是"ab"或者"ba"(返回一個即可);對於字元串"acbba",返回的應是"acb" 思路一:利用HaspMap,map的key存儲的是字元,value存儲的是字元當前的位置 1、如果當前字 ...


問題描述:給定一個字元串,找出這個字元串中最長的不重覆串。

比如:對於字元串"abcba",那麼返回的結果應該是"abc"或者"cba"(返回一個即可);對於字元串"acbba",返回的應是"acb"

思路:利用HaspMap,map的key存儲的是字元,value存儲的是字元當前的位置,利用containsKey()方法檢測是否有重覆
1、如果當前字元出現過並且index大於該字元上一次出現的index,那麼將map中該字元對應的value值替換,上一次出現的字元的下一個字元到當前字元變為目前新的子串,(此時子串不一定是最大長度的子串,而是程式運行過程中當前不重覆的子串)
2、如果目前新子串的長度(當前字元的index與startIndex(目前新子串的初始index)的差值 + 1)大於maxLen(最長不重覆子串長度),更新maxLen,如果要輸出這個不重覆子串,需要記錄startIndex
3、記錄當前字元的index
以"abcba"為例:
1、map.put('a',0),初始startIndex為0,maxLen為1,map.put('b',1),startIndex為0,maxLen為2,map.put('c',2),startIndex為0,maxLen為3,此時子串為"abc",map.put('b',3),檢測到有重覆,則目前新的子串變為‘cb’,將map中字元'b'的index替換為3,maxLen為2,startIndex變為2
2、目前新的子串為'cb',index為3,startIndex為2,長度為2,小於最大長度,不更新maxLen
掃描完以後,根據oriStartIndex(maxLen改變時記錄的startIndex)和maxLen來得到最長不重覆子串

具體代碼如下:

import java.util.HashMap;

public class findLongestSubString {
    public static void main(String[] args) {
        String str = "120135435";
        StringBuilder maxSubString = new StringBuilder("");  
        char[] strCharArr = str.toCharArray();  
        HashMap<Character, Integer> charsIndex = new HashMap<Character, Integer>();  
        int startIndex = 0, oriStartIndex = startIndex, maxLen = 0;  
        for(int index = 0; index < strCharArr.length; index++) {  
            if(charsIndex.containsKey(strCharArr[index])) {  
                int oriIndex = charsIndex.get(strCharArr[index]);  
                if(oriIndex >= startIndex){  
                    startIndex = oriIndex + 1;  
                }  
            }  
            if(index - startIndex + 1 > maxLen) {  
                maxLen = index - startIndex + 1;  
                oriStartIndex = startIndex;  
            }  
            charsIndex.put(strCharArr[index], index);  
        }  
        for(int index =  oriStartIndex; index < oriStartIndex + maxLen; index++) {  
            maxSubString.append(strCharArr[index]);  
        }  
        System.out.println(maxSubString.toString());
}

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

-Advertisement-
Play Games
更多相關文章
  • 添加樣式: 在html中,需要創建2層div來實現。一個div包含另一個div: 效果: ...
  • 表格控制項 Spread Studio 發佈了全新的 V11 CTP 版本。在此版本中,Spread For WinForms 引入了 Spread Common,也帶來了 Spread 性能的巨大提升和記憶體消耗的急劇下降。 ...
  • 1. 前言 做了WPF開發多年,一直未曾自己實現一個自定義Window Style,無論是《WPF編程寶典》或是各種博客都建議使用WindowStyle="None" 和 AllowsTransparency="True",於是想當然以為這樣就可以了。最近來了興緻想自己實現一個,才知道WindowS ...
  • Time Protocol(RFC-868)是一種非常簡單的應用層協議:它返回一個32位的二進位數字,這個數字描述了從1900年1月1日0時0分0秒到現在的秒數,伺服器在TCP的37號埠監聽時間協議請求。本函數將伺服器返回值轉化成本地時間。 先前不知道有現成的IPAddress.NetworkTo ...
  • 一、首先我們先講一下ref與out的區別和使用方法; 1、ref與out的區別: out:需要在使用前聲明變數,分配地址但不能賦值,但是需要在使用中的時候需要初始化(進入方法體中的時候需要先賦值在使用),至於為什麼要在方法體中使用,我個人認為是為了區別ref;(即只出不進) ref:需要在使用前聲明 ...
  • 請求過來,根據ip和埠,由iis伺服器進行接收,如果是靜態文件則直接返迴文件內容,如果無法解析,則根據映射規則找到對應請求尾碼 的ASPNET_ISAPI.dll處理程式集,交由其進行處理。 1.此時會生成IsapRuntime,其創建了WorkRequest對象, 2.接下來實例化HttpRun ...
  • HttpContext是ASP.NET中的核心對象,每一個請求都會創建一個對應的HttpContext對象,我們的應用程式便是通過HttpContext對象來獲取請求信息,最終生成響應,寫回到HttpContext中,完成一次請求處理。在前面幾章中也都有提到HttpContext,本章就來一起探索一 ...
  • 網站中的設置實現方式有好幾種,其中有將設置類序列化然後保存到文件中(例如使用XML序列化然後以XML形式保存在文件中),或者將設置信息保存到資料庫中。 保存到資料庫中的方式就是將設置的項作為key,設置的值作為value,以key-value(鍵值對)的形式保存。 下麵使用保存到資料庫中的例子來說明 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...