Go Java算法之外觀數(shù)列實現(xiàn)方法示例詳解
外觀數(shù)列
給定一個正整數(shù) n ,輸出外觀數(shù)列的第 n 項。
「外觀數(shù)列」是一個整數(shù)序列,從數(shù)字 1 開始,序列中的每一項都是對前一項的描述。
你可以將其視作是由遞歸公式定義的數(shù)字字符串序列:
countAndSay(1) = "1"
countAndSay(n) 是對 countAndSay(n-1) 的描述,然后轉(zhuǎn)換成另一個數(shù)字字符串。
前五項如下:
- 1、1 —— 第一項是數(shù)字 1
- 2、11 —— 描述前一項,這個數(shù)是 1 即 “ 一 個 1 ”,記作 "11"
- 3、21 —— 描述前一項,這個數(shù)是 11 即 “ 二 個 1 ” ,記作 "21"
- 4、1211 —— 描述前一項,這個數(shù)是 21 即 “ 一 個 2 + 一 個 1 ” ,記作 "1211"
- 5、111221 —— 描述前一項,這個數(shù)是 1211 即 “ 一 個 1 + 一 個 2 + 二 個 1 ” ,記作 "111221"
方法一:遍歷生成(Java)
所謂的「外觀數(shù)列」,其實本質(zhì)上只是依次統(tǒng)計字符串中連續(xù)相同字符的個數(shù)。
題目中給定的遞歸公式定義的數(shù)字字符串序列如下:
countAndSay(1) = "1";
countAndSay(n) 是對 countAndSay(n-1) 的描述,然后轉(zhuǎn)換成另一個數(shù)字字符串。
我們定義字符串 S_{i}表示countAndSay(i),我們?nèi)绻蟮?S_{n},則我們需先求出 S_{n-1},然后按照上述描述的方法生成,即從左到右依次掃描字符串 S_{n-1}中連續(xù)相同的字符的最大數(shù)目,然后將字符的統(tǒng)計數(shù)目轉(zhuǎn)化為數(shù)字字符串再連接上對應(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 為生成的字符串中的最大長度
時間復雜度:O(N * M)
空間復雜度:O(M)
方法二:遞歸(Go)
具體的方法分析已經(jīng)在上文中表述
由于每次得到的數(shù)據(jù)都是來源于上一次的結(jié)果,所以我們可以假設(shè)得到了上次的結(jié)果,繼而往后運算。這就運用到了遞歸。
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 為生成的字符串中的最大長度
時間復雜度:O(N * M)
空間復雜度:O(M)
以上就是Go Java算法之外觀數(shù)列實現(xiàn)方法示例詳解的詳細內(nèi)容,更多關(guān)于Go Java算法外觀數(shù)列的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java中final關(guān)鍵字的使用與注意總結(jié)
這篇文章主要給大家介紹了關(guān)于Java中final關(guān)鍵字的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2020-08-08SpringBoot + Spring Cloud Consul 服務(wù)注冊和發(fā)現(xiàn)詳細解析
這篇文章主要介紹了SpringBoot + Spring Cloud Consul 服務(wù)注冊和發(fā)現(xiàn),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet的問題解決
最近在寫一個javaweb項目,但是在IDEA中創(chuàng)建好項目后,在搭建結(jié)構(gòu)的時候創(chuàng)建servlet文件去沒有選項,所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet問題的解決方法,需要的朋友可以參考下2023-10-10java實時監(jiān)控文件行尾內(nèi)容的實現(xiàn)
這篇文章主要介紹了java實時監(jiān)控文件行尾內(nèi)容的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02SpringBoot整合Elasticsearch并實現(xiàn)CRUD操作
這篇文章主要介紹了SpringBoot整合Elasticsearch并實現(xiàn)CRUD操作,需要的朋友可以參考下2018-03-03