javascript獲取重復(fù)次數(shù)最多的字符
javascript獲取重復(fù)次數(shù)最多的字符
/** 取出字符串中重復(fù)字?jǐn)?shù)最多的字符 */ var words = 'sdfghjkfastgbyhnvdstyaujskgfdfhlaa'; //創(chuàng)建字符串 var word, //單個(gè)字符 length; //該字符的長(zhǎng)度 //定義輸出對(duì)象 var max = { wordName : '', //重復(fù)次數(shù)最多的字符 wordLength : 0 //重復(fù)的次數(shù) }; //遞歸方法,傳入字符串 (function(words) { if (!words) return; //如果字符串已經(jīng)變空則返回,結(jié)束遞歸 word = words[0]; //取出字符串中的第一個(gè)字符 length = words.length; //將length設(shè)為當(dāng)前字符串長(zhǎng)度 words = words.replace(new RegExp(word, 'g'), ''); //返回將字符串剔除當(dāng)前字符的剩余字符串 length = length - words.length; //重設(shè)length為當(dāng)前字符在字符串中的長(zhǎng)度 if (length > max.wordLength) //如果該字符重復(fù)次數(shù)大于maxLength,則重設(shè)maxLength為當(dāng)前字符重復(fù)次數(shù) max = { //重設(shè)對(duì)象的值 wordName : word, wordLength : length }; arguments.callee(words); //遞歸調(diào)用,傳入剩余字符串 })(words); console.log(max.wordName+"\n"+max.wordLength); //遞歸結(jié)束后輸出結(jié)果
今天上午偶然看見(jiàn)這樣的一個(gè)問(wèn)題.看到網(wǎng)上大部分是用兩個(gè)循環(huán)做出來(lái)的.然后自己用遞歸寫(xiě)了一下
思路是
每遞歸一次.取出第一個(gè)字符.從字符串中剔除相同符號(hào)的字符,并拿之前的字符串長(zhǎng)度減去剔除后的字符串長(zhǎng)度.
得到的是該字符串中當(dāng)前字符所重復(fù)次數(shù).
判斷該字符重復(fù)次數(shù)是否大于當(dāng)前輸出對(duì)象中存儲(chǔ)的maxLength.
如true,則更新
然后進(jìn)入下次遞歸,直到字符串被替換完,終止
輸出對(duì)象中存儲(chǔ)的就是次數(shù)最多的字符以及重復(fù)的次數(shù)
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- JS字符串統(tǒng)計(jì)操作示例【遍歷,截取,輸出,計(jì)算】
- js對(duì)圖片base64編碼字符串進(jìn)行解碼并輸出圖像示例
- JavaScript實(shí)現(xiàn)查找字符串中第一個(gè)不重復(fù)的字符
- js去除重復(fù)字符串兩種實(shí)現(xiàn)方法
- JS使用正則表達(dá)式除去字符串中重復(fù)字符的方法
- JS刪除字符串中重復(fù)字符方法
- JS清除字符串中重復(fù)值的實(shí)現(xiàn)方法
- JS字符串去除連續(xù)或全部重復(fù)字符的實(shí)例
- js中console在一行內(nèi)打印字符串和對(duì)象的方法
- javaScript 實(shí)現(xiàn)重復(fù)輸出給定的字符串的常用方法小結(jié)
相關(guān)文章
JavaScript prototype屬性使用說(shuō)明
prototype 是在 IE 4 及其以后版本引入的一個(gè)針對(duì)于某一類的對(duì)象的方法,而且特殊的地方便在于:它是一個(gè)給類的對(duì)象添加方法的方法!2010-05-05詳解webpack4升級(jí)指南以及從webpack3.x遷移
本篇文章主要介紹了詳解webpack4升級(jí)指南以及從webpack3.x遷移,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06JavaScript實(shí)現(xiàn)把rgb顏色轉(zhuǎn)換成16進(jìn)制顏色的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)把rgb顏色轉(zhuǎn)換成16進(jìn)制顏色的方法,涉及javascript實(shí)現(xiàn)數(shù)制轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2015-06-06JavaScript實(shí)現(xiàn)圖片合成下載的示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)圖片合成下載的示例,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下2020-11-11JavaScript實(shí)現(xiàn)點(diǎn)擊單選按鈕改變輸入框中文本域內(nèi)容的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)點(diǎn)擊單選按鈕改變輸入框中文本域內(nèi)容的方法,涉及javascript單選按鈕控制頁(yè)面元素樣式的相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-08-08JavaScript從數(shù)組(數(shù)組對(duì)象)中刪除特定數(shù)據(jù)的方法
這篇文章主要給大家介紹了關(guān)于JavaScript從數(shù)組(數(shù)組對(duì)象)中刪除特定數(shù)據(jù)的相關(guān)資料,js在前臺(tái)界面中舉足輕重,在使用js刪除數(shù)組時(shí)遇到一些問(wèn)題,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09JavaScript實(shí)現(xiàn)手機(jī)號(hào)碼 3-4-4格式并控制新增和刪除時(shí)光標(biāo)的位置
這篇文章主要介紹了JavaScript實(shí)現(xiàn)手機(jī)號(hào)碼 3-4-4格式并控制新增和刪除時(shí)光標(biāo)的位置,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06JavaScript實(shí)現(xiàn)點(diǎn)擊自制菜單效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)點(diǎn)擊自制菜單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-02-02