leetcode38报数

leetcode38 Count and Say

Posted by BY on February 15, 2019

前言

新的一年,好好学习

正文

问题来源

本问题来自leetcode上的40题。

问题描述

报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下:

  1. 1
  2. 11
  3. 21
  4. 1211
  5. 111221
    1 被读作 “one 1” (“一个一”) , 即 11。
    11 被读作 “two 1s” (“两个一”), 即 21。
    21 被读作 “one 2”, “one 1” (”一个二” , “一个一”) , 即 1211。
    给定一个正整数 n(1 ≤ n ≤ 30),输出报数序列的第 n 项。
    注意:整数顺序将表示为一个字符串。

示例 1:

输入: 1
输出: "1"

示例 2:

输入: 4
输出: "1211"

分析:

func countAndSay(n int) string {
    ret := "1"
    for i := 1; i < n; i++ {
        temp := ""
        for j := 0; j < len(ret);  {
            a := ret[j]
            k := 1
            j++
            for j < len(ret) && a == ret[j] {
                k++
                j++
            }
            temp = fmt.Sprintf("%s%d%c",temp,k,a)
            
        }
        ret = temp
    }
    return ret
}

提交之后发现内存消耗了6M多。

总结:

勤思考。

结语

不管怎么样好好加油。