java 記錄一個(gè)子串在整串中出現(xiàn)的次數(shù)實(shí)例
任務(wù)描述:
編寫(xiě)一個(gè)程序,記錄一個(gè)子串在整串中出現(xiàn)的次數(shù),例如記錄子串“nba”在整串“nbaernbatnbaynbauinbaopnba”中出現(xiàn)的次數(shù),通過(guò)觀察可知子串“nba”出現(xiàn)的次數(shù)為6.要求使用String類的常用方法來(lái)計(jì)算出現(xiàn)的次數(shù)。
任務(wù)目標(biāo):
學(xué)會(huì)分析“記錄一個(gè)子串在整串中出現(xiàn)的次數(shù)”任務(wù)的實(shí)現(xiàn)思路
根據(jù)思路獨(dú)立完成“記錄一個(gè)子串在整串中出現(xiàn)的次數(shù)”任務(wù)的源代碼編寫(xiě)、編譯及運(yùn)行。
掌握String類中常用方法的使用。
public class Demo01 { public static void main(String[] args) { String s= "nbaernbatynbauinbaopnba"; String key="nba"; int count=count(s,key); System.out.println(count); } public static int count(String s, String key) { int count=0; int d=0; while((d=s.indexOf(key,d))!=-1){ s=s.substring(d+key.length()); count++; } return count; } }
實(shí)現(xiàn)思路:
(1)分析任務(wù)描述可知,做此任務(wù)需要先定義兩個(gè)字符串,一個(gè)表示子串,一個(gè)表示整串。
(2)要查找子串在整串中出現(xiàn)的次數(shù),可以先使用String類的contain()方法,判斷整串中是否包含子串,如果不包含,那么不用計(jì)算,子串在整串中出現(xiàn)的次數(shù)一定為0。
(3)如果整串中包含了子串,那么再具體計(jì)算出現(xiàn)的次數(shù)。使用String類的indexOf()方法可以獲取子串在整串中第一次出現(xiàn)的索引。獲取到之后,再在整串中該索引加上子串長(zhǎng)度的位置處繼續(xù)查找子串(可以通過(guò)String類的subString()方法將整串的剩余部分截取出來(lái),然后在剩余整串中從頭查找子串)。依次類推,通過(guò)循環(huán)完成查找,直到找不到子串為止,此時(shí)indexOf()方法的返回值為-1.
(4)定義一個(gè)計(jì)數(shù)器,記錄出現(xiàn)的次數(shù),在循環(huán)中每查到一次子串,則計(jì)數(shù)器加1.
以上這篇java 記錄一個(gè)子串在整串中出現(xiàn)的次數(shù)實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot中使用JSR-303實(shí)現(xiàn)請(qǐng)求參數(shù)校驗(yàn)
這篇文章主要介紹了Spring Boot中使用JSR-303實(shí)現(xiàn)請(qǐng)求參數(shù)校驗(yàn),JSR-303校驗(yàn)我們一般都是對(duì)Java的實(shí)體類對(duì)象進(jìn)行校驗(yàn),主要檢驗(yàn)JSR-303是Java中的一個(gè)規(guī)范,用于實(shí)現(xiàn)請(qǐng)求參數(shù)校驗(yàn)在我們的實(shí)體類對(duì)象的屬性上,感興趣的朋友跟隨小編一起看看吧2023-10-10