Go Java算法之外觀數(shù)列實(shí)現(xiàn)方法示例詳解
外觀數(shù)列
給定一個(gè)正整數(shù) n ,輸出外觀數(shù)列的第 n 項(xiàng)。
「外觀數(shù)列」是一個(gè)整數(shù)序列,從數(shù)字 1 開始,序列中的每一項(xiàng)都是對(duì)前一項(xiàng)的描述。
你可以將其視作是由遞歸公式定義的數(shù)字字符串序列:
countAndSay(1) = "1"
countAndSay(n) 是對(duì) countAndSay(n-1) 的描述,然后轉(zhuǎn)換成另一個(gè)數(shù)字字符串。
前五項(xiàng)如下:
- 1、1 —— 第一項(xiàng)是數(shù)字 1
- 2、11 —— 描述前一項(xiàng),這個(gè)數(shù)是 1 即 “ 一 個(gè) 1 ”,記作 "11"
- 3、21 —— 描述前一項(xiàng),這個(gè)數(shù)是 11 即 “ 二 個(gè) 1 ” ,記作 "21"
- 4、1211 —— 描述前一項(xiàng),這個(gè)數(shù)是 21 即 “ 一 個(gè) 2 + 一 個(gè) 1 ” ,記作 "1211"
- 5、111221 —— 描述前一項(xiàng),這個(gè)數(shù)是 1211 即 “ 一 個(gè) 1 + 一 個(gè) 2 + 二 個(gè) 1 ” ,記作 "111221"
方法一:遍歷生成(Java)
所謂的「外觀數(shù)列」,其實(shí)本質(zhì)上只是依次統(tǒng)計(jì)字符串中連續(xù)相同字符的個(gè)數(shù)。
題目中給定的遞歸公式定義的數(shù)字字符串序列如下:
countAndSay(1) = "1";
countAndSay(n) 是對(duì) countAndSay(n-1) 的描述,然后轉(zhuǎn)換成另一個(gè)數(shù)字字符串。
我們定義字符串 S_{i}表示countAndSay(i),我們?nèi)绻蟮?S_{n},則我們需先求出 S_{n-1},然后按照上述描述的方法生成,即從左到右依次掃描字符串 S_{n-1}中連續(xù)相同的字符的最大數(shù)目,然后將字符的統(tǒng)計(jì)數(shù)目轉(zhuǎn)化為數(shù)字字符串再連接上對(duì)應(yīng)的字符。
class Solution { public String countAndSay(int n) { String str = "1"; for (int i = 2; i <= n; ++i) { StringBuilder sb = new StringBuilder(); int start = 0; int pos = 0; while (pos < str.length()) { while (pos < str.length() && str.charAt(pos) == str.charAt(start)) { pos++; } sb.append(Integer.toString(pos - start)).append(str.charAt(start)); start = pos; } str = sb.toString(); } return str; } }
N 為給定的正整數(shù),M 為生成的字符串中的最大長(zhǎng)度
時(shí)間復(fù)雜度:O(N * M)
空間復(fù)雜度:O(M)
方法二:遞歸(Go)
具體的方法分析已經(jīng)在上文中表述
由于每次得到的數(shù)據(jù)都是來(lái)源于上一次的結(jié)果,所以我們可以假設(shè)得到了上次的結(jié)果,繼而往后運(yùn)算。這就運(yùn)用到了遞歸。
func countAndSay(n int) string { if n == 1 { return "1" } s := countAndSay(n - 1) i, res := 0, "" length := len(s) for j := 0; j < length; j++ { if s[j] != s[i] { res += strconv.Itoa(j-i) + string(s[i]) i = j } } res += strconv.Itoa(length-i) + string(s[i]) return res }
N 為給定的正整數(shù),M 為生成的字符串中的最大長(zhǎng)度
時(shí)間復(fù)雜度:O(N * M)
空間復(fù)雜度:O(M)
以上就是Go Java算法之外觀數(shù)列實(shí)現(xiàn)方法示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Go Java算法外觀數(shù)列的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java 同步器SynchronousQueue詳解及實(shí)例
這篇文章主要介紹了java 同步器SynchronousQueue詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-05-05Java中final關(guān)鍵字的使用與注意總結(jié)
這篇文章主要給大家介紹了關(guān)于Java中final關(guān)鍵字的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用Java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08SpringBoot + Spring Cloud Consul 服務(wù)注冊(cè)和發(fā)現(xiàn)詳細(xì)解析
這篇文章主要介紹了SpringBoot + Spring Cloud Consul 服務(wù)注冊(cè)和發(fā)現(xiàn),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07Maven依賴junit?@Test報(bào)錯(cuò)的解決方案
這篇文章主要介紹了Maven依賴junit?@Test報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03idea2023創(chuàng)建JavaWeb教程之右鍵沒(méi)有Servlet的問(wèn)題解決
最近在寫一個(gè)javaweb項(xiàng)目,但是在IDEA中創(chuàng)建好項(xiàng)目后,在搭建結(jié)構(gòu)的時(shí)候創(chuàng)建servlet文件去沒(méi)有選項(xiàng),所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于idea2023創(chuàng)建JavaWeb教程之右鍵沒(méi)有Servlet問(wèn)題的解決方法,需要的朋友可以參考下2023-10-10java實(shí)時(shí)監(jiān)控文件行尾內(nèi)容的實(shí)現(xiàn)
這篇文章主要介紹了java實(shí)時(shí)監(jiān)控文件行尾內(nèi)容的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02SpringBoot整合Elasticsearch并實(shí)現(xiàn)CRUD操作
這篇文章主要介紹了SpringBoot整合Elasticsearch并實(shí)現(xiàn)CRUD操作,需要的朋友可以參考下2018-03-03Java實(shí)現(xiàn)添加文字水印和圖片水印功能
為圖片添加水印是一種常用的圖片處理技術(shù),本文主要介紹了Java實(shí)現(xiàn)添加文字水印和圖片水印功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05