国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

如何利用JavaScript獲取字符串中重復次數最多的字

發(fā)布時(shí)間:2021-08-17 12:16 來(lái)源: 閱讀:0 作者:編程三昧 欄目: JavaScript 歡迎投稿:712375056

目錄

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

    題目

    假設有這么一道題目:請獲取字符串 "bianchengsanmei,xuexiyouqudezhishi,jieshiyouqudepengyou,suzaoyouqudelinghun." 中重復次數最多的字符及其重復次數。

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

    分析

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

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

    使用對象

    解題思路:

    • 遍歷字符串,以各個(gè)字符為 key,重復次數為 value,存入一個(gè)對象。
    • 遍歷對象,得到 value 的最大值。
    • 遍歷對象,根據得到的最大 value 值,獲取到對應的字符 key。
    • 輸出結果。

    代碼實(shí)現如下:

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

    分析:

    • 這應該是很多人第一時(shí)間能夠想到的解法,很符合“面向過(guò)程”的編程思想。
    • 總共有三個(gè)循環(huán),存在較大的優(yōu)化空間。

    數組&指針

    解題思路:

    • 將字符串轉為數組并排序,使重復字符排在一起。
    • 使用指針思想,得到最大重復次數和對應的字符數組。
    • 輸出結果。

    代碼實(shí)現如下:

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

    分析:

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

    總結

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

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

    到此這篇關(guān)于如何利用JavaScript獲取字符串中重復次數最多的字符的文章就介紹到這了,更多相關(guān)JS獲取重復次數最多字符內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

    免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

    日韩中文无码有码免费视频| 国产精品沙发午睡系列990531| 亚洲精品无码专区在线播放| 国产成人精品亚洲一区二区三区| 另类亚洲小说图片综合区| 国产香蕉尹人在线观看视频|