溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么利用JavaScript獲取字符串中重復(fù)次數(shù)最多的字符

發(fā)布時(shí)間:2021-07-07 17:20:44 來(lái)源:億速云 閱讀:111 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“怎么利用JavaScript獲取字符串中重復(fù)次數(shù)最多的字符”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

目錄
  • 題目

  • 分析

  • 使用對(duì)象

    • 解題思路:

    • 代碼實(shí)現(xiàn)如下:

    • 分析:

  • 數(shù)組&指針

    • 解題思路:

    • 代碼實(shí)現(xiàn)如下:

    • 分析:

  • 總結(jié)

    想要保持自己的技術(shù)活力,最有效的手段就是通過(guò)不斷地輸入來(lái)提供足夠的養(yǎng)分。我們也不必刻意追求高深的或者新鮮的知識(shí)點(diǎn),通過(guò)對(duì)一個(gè)基礎(chǔ)問(wèn)題的全方位多維度解析,同樣也會(huì)收獲不小。

    題目

    假設(shè)有這么一道題目:請(qǐng)獲取字符串 "bianchengsanmei,xuexiyouqudezhishi,jieshiyouqudepengyou,suzaoyouqudelinghun." 中重復(fù)次數(shù)最多的字符及其重復(fù)次數(shù)。

    今天我們就來(lái)解一下這道題。

    分析

    這種題目的解法比較開放,實(shí)現(xiàn)手段也可能多種多樣,其中的區(qū)別在于代碼的運(yùn)行性能有高有低(時(shí)間復(fù)雜度和空間復(fù)雜度不同)。

    在這里需要注意的只有一點(diǎn):符合最大次數(shù)的字符可能不止一個(gè)。

    使用對(duì)象

    解題思路:

    • 遍歷字符串,以各個(gè)字符為 key,重復(fù)次數(shù)為 value,存入一個(gè)對(duì)象。

    • 遍歷對(duì)象,得到 value 的最大值。

    • 遍歷對(duì)象,根據(jù)得到的最大 value 值,獲取到對(duì)應(yīng)的字符 key。

    • 輸出結(jié)果。

    代碼實(shí)現(xiàn)如下:

    const testStr = "bianchengsanmei,xuexiyouqudezhishi,jieshiyouqudepengyou,suzaoyouqudelinghun.ii";
    
    // 獲取各個(gè)字符及其重復(fù)次數(shù)的映射對(duì)象
    let wordsObj = {};
    for (let index = 0; index < testStr.length; index++) {
        const word = testStr[index];
        word in wordsObj ? wordsObj[word]++ : wordsObj[word] = 1;
    }
    
    // 獲取最大的重復(fù)次數(shù)
    let maxNum = 0;
    for (const word in wordsObj) {
        const num = wordsObj[word];
        if (num >= maxNum) {
            maxNum = num;
        }
    }
    
    // 獲取最大重復(fù)次數(shù)對(duì)應(yīng)的字符,并輸出結(jié)果
    for (const word in wordsObj) {
        const num = wordsObj[word];
        if (num === maxNum) {
            console.log(`重復(fù)次數(shù)最多的字符是:${ word },重復(fù)次數(shù)為:${ maxNum }`)
        }
    }
    
    // 出現(xiàn)次數(shù)最多的字符是:i,出現(xiàn)次數(shù)為:10
    // 出現(xiàn)次數(shù)最多的字符是:u,出現(xiàn)次數(shù)為:10

    分析:

    • 這應(yīng)該是很多人第一時(shí)間能夠想到的解法,很符合“面向過(guò)程”的編程思想。

    • 總共有三個(gè)循環(huán),存在較大的優(yōu)化空間。

    數(shù)組&指針

    解題思路:

    • 將字符串轉(zhuǎn)為數(shù)組并排序,使重復(fù)字符排在一起。

    • 使用指針?biāo)枷?,得到最大重?fù)次數(shù)和對(duì)應(yīng)的字符數(shù)組。

    • 輸出結(jié)果。

    代碼實(shí)現(xiàn)如下:

    const testStr = "bianchengsanmei,xuexiyouqudezhishi,jieshiyouqudepengyou,suzaoyouqudelinghun.ii";
    
    // 將字符串轉(zhuǎn)為數(shù)組并排序
    const testStrArr = testStr.split("").sort();
    let startIndex = 0;
    let endIndex = 1;
    let maxNum = 0;
    let validWords = [];
    
    // 使用指針?lè)?,獲取最大重復(fù)次數(shù)及最大次數(shù)對(duì)應(yīng)的字符數(shù)組
    while (startIndex < testStrArr.length) {
        // startIndex 和 endIndex 位置的字符不同
        if (testStrArr[startIndex] !== testStrArr[endIndex]) {
            // 計(jì)算 startIndex 和 endIndex 之間的字符個(gè)數(shù)
            const rangeNum = endIndex - startIndex;
            if (rangeNum > maxNum) {
                maxNum = rangeNum;
                // 如果出現(xiàn)了新的最大次數(shù),則給存放符合條件字符的數(shù)組重新賦值
                validWords = [testStrArr[startIndex]];
            } else if (rangeNum === maxNum) {
                // 如果新的次數(shù)和最大次數(shù)相等,則將該字符 push 進(jìn)字符數(shù)組
                validWords.push(testStrArr[startIndex]);
            }
            startIndex = endIndex;
        }
        endIndex++;
    }
    
    // 打印結(jié)果
    for (let index = 0; index < validWords.length; index++) {
        const word = validWords[index];
        console.log(`重復(fù)次數(shù)最多的是:${ word },重復(fù)次數(shù)為:${ maxNum }`)
    }

    分析:

    本方法的難點(diǎn)和精髓在于使用了指針?lè)?,一次循環(huán)就獲取到了我們想要的結(jié)果。

    總結(jié)

    主流的解題思路大概就這兩種,其他的很多解法都可以看作是這兩種思路的變種。

    萬(wàn)變不離其宗,只要將解題思路理清了,代碼實(shí)現(xiàn)只是一個(gè)結(jié)果而已。在平常的工作學(xué)習(xí)中,我們要有意識(shí)地培養(yǎng)自己的發(fā)散性思維,從多角度去看待問(wèn)題,你可能會(huì)發(fā)現(xiàn)不一樣的風(fēng)景哦!

    “怎么利用JavaScript獲取字符串中重復(fù)次數(shù)最多的字符”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI