欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go Java算法之外觀數(shù)列實現(xiàn)方法示例詳解

 更新時間:2022年08月10日 16:43:00   作者:黃丫丫  
這篇文章主要為大家介紹了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 同步器SynchronousQueue詳解及實例

    java 同步器SynchronousQueue詳解及實例

    這篇文章主要介紹了java 同步器SynchronousQueue詳解及實例的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • Java中final關(guān)鍵字的使用與注意總結(jié)

    Java中final關(guān)鍵字的使用與注意總結(jié)

    這篇文章主要給大家介紹了關(guān)于Java中final關(guān)鍵字的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2020-08-08
  • Java多線程之線程狀態(tài)的遷移詳解

    Java多線程之線程狀態(tài)的遷移詳解

    線程狀態(tài)遷移,又常被稱作線程的生命周期,指的是線程從創(chuàng)建到終結(jié)需要經(jīng)歷哪些狀態(tài),什么情況下會出現(xiàn)哪些狀態(tài).線程的狀態(tài)直接關(guān)系著并發(fā)編程的各種問題,本文就線程的狀態(tài)遷移做一初步探討,并總結(jié)在何種情況下會出現(xiàn)這些狀態(tài),需要的朋友可以參考下
    2021-06-06
  • SpringBoot + Spring Cloud Consul 服務(wù)注冊和發(fā)現(xiàn)詳細解析

    SpringBoot + Spring Cloud Consul 服務(wù)注冊和發(fā)現(xiàn)詳細解析

    這篇文章主要介紹了SpringBoot + Spring Cloud Consul 服務(wù)注冊和發(fā)現(xiàn),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • Maven依賴junit?@Test報錯的解決方案

    Maven依賴junit?@Test報錯的解決方案

    這篇文章主要介紹了Maven依賴junit?@Test報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet的問題解決

    idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet的問題解決

    最近在寫一個javaweb項目,但是在IDEA中創(chuàng)建好項目后,在搭建結(jié)構(gòu)的時候創(chuàng)建servlet文件去沒有選項,所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于idea2023創(chuàng)建JavaWeb教程之右鍵沒有Servlet問題的解決方法,需要的朋友可以參考下
    2023-10-10
  • SpringMVC的概念以及快速入門示例

    SpringMVC的概念以及快速入門示例

    這篇文章主要介紹了SpringMVC的概念以及快速入門示例,SpringMVC 已經(jīng)成為目前最主流的MVC框架之一,它通過一套注解,讓一個簡單的 Java 類成為處理請求的控制器,而無須實現(xiàn)任何接口,需要的朋友可以參考下
    2023-05-05
  • java實時監(jiān)控文件行尾內(nèi)容的實現(xiàn)

    java實時監(jiān)控文件行尾內(nèi)容的實現(xiàn)

    這篇文章主要介紹了java實時監(jiān)控文件行尾內(nèi)容的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • SpringBoot整合Elasticsearch并實現(xiàn)CRUD操作

    SpringBoot整合Elasticsearch并實現(xiàn)CRUD操作

    這篇文章主要介紹了SpringBoot整合Elasticsearch并實現(xiàn)CRUD操作,需要的朋友可以參考下
    2018-03-03
  • Java實現(xiàn)添加文字水印和圖片水印功能

    Java實現(xiàn)添加文字水印和圖片水印功能

    為圖片添加水印是一種常用的圖片處理技術(shù),本文主要介紹了Java實現(xiàn)添加文字水印和圖片水印功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05

最新評論