Go Java算法之外觀數(shù)列實(shí)現(xiàn)方法示例詳解
外觀數(shù)列
給定一個(gè)正整數(shù) n ,輸出外觀數(shù)列的第 n 項(xiàng)。
「外觀數(shù)列」是一個(gè)整數(shù)序列,從數(shù)字 1 開(kāi)始,序列中的每一項(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中final,finally,finalize三個(gè)關(guān)鍵字的區(qū)別_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章給大家收集整理了有關(guān)java中final,finally,finalize三個(gè)關(guān)鍵字的區(qū)別介紹,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-04-04
解決SpringBoot項(xiàng)目讀取yml文件中值為中文時(shí),在視圖頁(yè)面顯示亂碼
這篇文章主要介紹了解決SpringBoot項(xiàng)目讀取yml文件中值為中文時(shí),在視圖頁(yè)面顯示亂碼的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
SpringBoot使用AOP統(tǒng)一日志管理的方法詳解
這篇文章主要為大家分享一個(gè)干貨:超簡(jiǎn)潔SpringBoot使用AOP統(tǒng)一日志管理,文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
IntelliJ IDEA打開(kāi)多個(gè)Maven的module且相互調(diào)用代碼的方法
這篇文章主要介紹了IntelliJ IDEA打開(kāi)多個(gè)Maven的module且相互調(diào)用代碼的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-02-02
Java實(shí)現(xiàn)的兩種常見(jiàn)簡(jiǎn)單查找算法示例【快速查找與二分查找】
這篇文章主要介紹了Java實(shí)現(xiàn)的兩種常見(jiàn)簡(jiǎn)單查找算法,結(jié)合具體實(shí)例形式分析了java快速查找與二分查找的原理與簡(jiǎn)單實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-09-09
java實(shí)戰(zhàn)小技巧之優(yōu)雅的實(shí)現(xiàn)字符串拼接
字符串拼接是我們?cè)贘ava代碼中比較經(jīng)常要做的事情,就是把多個(gè)字符串拼接到一起,這篇文章主要給大家介紹了關(guān)于java實(shí)戰(zhàn)小技巧之優(yōu)雅的實(shí)現(xiàn)字符串拼接的相關(guān)資料,需要的朋友可以參考下2021-08-08

